python全栈开发day62-两表操作增删改查,外键,if else模板语法
一、今日内容总结:
day62
内容回顾:
1. django有关所有命令:
pip install django==1.11.14
django-admin startproject 项目名称
cd 项目
python manage.py runserver 80 0.0.0.0:80
python manage.py startapp app01
python manage.py makemigrations # 保存models修改记录
python manage.py migrate # 操作数据表 2. settings相关:
1. templates 模板相关 DIRS
2. static 静态文件相关
STATIC_URL = '/static/'
STATICFILES_DIRS = [
os.path.join(BASE_DIR,'static')
]
3. 注释CSRF中间件 方便你提交POST请求
4. DATABASES
引擎:mysql
NAME: 数据库名称
HOST:IP地址
PORT: 端口号 3306
USER: 用户名 root
PASSWORD: 密码 ''
5. APP
INSTALLED_APPS=[
'app01',
'app01.apps.App01Config'
]
3.GET和POST
GET:
1.form表单 默认get请求
2.直接在浏览器输入URL
3.a标签 127.0.0.1:8000/add_publisher/?id=1&name=alex request.GET 大字典
request.GET.get('id','')
request.GET['id']
POST:
form表单提交 method='post' 参数不在URL显示,参数在请求体当中 request.POST 大字典
request.POST.get('id','')
request.POST['id']
4. mysql数据的使用:
1. 创建mysql数据库
2. settings.py中要配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'day61',
'HOST': '127.0.0.1',
'PORT': 3306,
'USER': 'root',
'PASSWORD': '',
}
}
3. 告诉django使用pymysql来连接数据库:
在与项目同名的文件夹下的__init__.py文件中写:
import pymysql
pymysql.install_as_MySQLdb()
4. 在app01/models.py写类(必须继承models.Model)
class Publisher(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=32,null=False,unique=True) 5. 执行数据库迁移两条命令
python manage.py makemigrations # 保存models修改记录
python manage.py migrate # 操作数据表
5. ORM操作:
1. 查
models.Publisher.objects.all() # 查询所有的对象 ——》对象列表 QuerySet
models.Publisher.objects.get(id='') # 查询一个对象 ——》单独的对象
models.Publisher.objects.filter(id='') # 查询所有符合条件的对象 ——》对象列表 QuerySet
models.Publisher.objects.filter(id='').order_by('id') 2. 增
models.Publisher.objects.create(name='xinhuachubanshe') 3. 删
# 删除一个对象
obj_list = models.Publisher.objects.filter(id='')
obj_list[0].delete()
# 删除所有符合条件的对象
models.Publisher.objects.filter(id='').delete() 4. 改
obj_list = models.Publisher.objects.filter(id='')
obj = obj_list[0]
obj.name = 'asdasd'
obj.save()
6. 模板语法:
render(request,'HTML文件',{'publishers':obj_list}) {{ 变量 }} for 循环
{% for i in publishers %}
{{ i.name }}
{% endfor %} 今日内容:
1. 设计图书管理系统的表结构
书 出版社 作者 书和出版社 多对一
书和作者 多对多 2. 书的增删改查 3. 外键
class Book(models.Model):
id = models.AutoField(primary_key=True)
title = models.CharField(max_length=32, null=False, unique=True)
publisher = models.ForeignKey(to='Publisher',on_delete=models.CASCADE) books = models.Book.objects.all() for book in books:
print(book.publisher_id) # 数据库中的id
print(book.publisher) # 关联的对象
# print(book.publisher.addr)
print('=' * 30) 创建外键关联的方式 publisher = 关联的对象
publisher_obj = models.Publisher.objects.get(id=publisher_id)
book_obj = models.Book.objects.create(title=title, publisher=publisher_obj) publisher_id = 关联对象的id
book_obj = models.Book.objects.create(title=title, publisher_id=publisher_id) 4. 模板相关
{% if edit_book.publisher_id == publish.id %}
<option value="{{ publish.id }}" selected>{{ publish.name }}</option>
{% elif 其他条件 %}
操作
{% else %}
<option value="{{ publish.id }}">{{ publish.name }}</option>
{% endif %}
课上笔记
1.if模板语法
{% if 条件%}
操作....
{%elif 条件%}
操作
{%endif%}
2.外键
publisher = models.ForeignKey(to='Publisher')
操作时:
obj.publisher = 对象
或
obj.publisher_id = id
3.两种改方法不一样
obj1 = edit_obj_list[0] obj2 = edit_obj_list[0]
两者值一样,但内存地址id不一样
edit_obj_list[0].name = new_name
edit_obj_list[0].save()
和
obj = edit_obj_list[0]
obj.name = new_name
obj.save()
不一样
4.其他
二、预习和扩展
1.str 和 repr
列表【】中的对象 直接打印列表会调用repr,因为列表时机器,直接打印对象会调用str
python全栈开发day62-两表操作增删改查,外键,if else模板语法的更多相关文章
- python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)
一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...
- 巨蟒python全栈开发django7:多表增加和查询
1.回顾内容&&补充 补充1: 补充2: 这个选择的是第二个解释器. 选择第一个的话,只是针对当前的项目,如果再开新项目的话,需要重新下载安装相关的包. 点击保存,因为我们注释掉了,创 ...
- django模型层之多表操作 增删改查
多表操作之创建模型 这边以书为中心创建一个模型 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是一对一的关系(on ...
- Django学习笔记--数据库中的单表操作----增删改查
1.Django数据库中的增删改查 1.添加表和字段 # 创建的表的名字为app的名称拼接类名 class User(models.Model): # id字段 自增 是主键 id = models. ...
- $Django 多表操作(增删改查,基于双下划线,对象的查询) 在Python脚本中调用Django环境
在Python脚本中调用Django环境. import osif __name__ == '__main__': os.environ.setdefault("DJANGO_SETTING ...
- python全栈开发 * 表格标签 表单标签 css 引入方式 * 180807
html部分 一.表格标签<table> 1.一个表格<table>由每行<tr>组成的,每行是由<td>组成的. 注意: 一个表格是由行组成的(行是由 ...
- python 全栈开发,Day101(redis操作,购物车,DRF解析器)
昨日内容回顾 1. django请求生命周期? - 当用户在浏览器中输入url时,浏览器会生成请求头和请求体发给服务端 请求头和请求体中会包含浏览器的动作(action),这个动作通常为get或者po ...
- python 全栈开发,Day8(文件操作)
一.文件操作流程 文件以什么编码存储的,就以什么编码打开 参数: 1.文件路径 2.编码方式,encode 3.执行动作(打开方式):只读,只写,追加,读写,写读... 打开一个已经存在的文件 f = ...
- python 全栈开发,Day71(模型层-单表操作)
昨日内容回顾 1. {% include '' %} 2. extend base.html: <html> ..... ..... ..... {% block content%} {% ...
随机推荐
- CTex+WinEdt10.2安装详细教程与破解
原文地址:https://www.cnblogs.com/xiachongkun/p/8176390.html Latex作为目前最好用的文档编排工具,以前只是简单会一点,现在也已经忘得差不多了.因为 ...
- Cannot open Eclipse Marketplace
(1) window->preferences->General->Network Connections,Active Provider处勾选Manual (2)在eclipse. ...
- SyntaxError: JSON.parse: unexpected character at line 1 column 1 of the JSON data错误的解决
记录个报错: 问题描述: 经过服务器生成图片返到前台时,在火狐浏览器中下载图片或打开图片时报错:SyntaxError: JSON.parse: unexpected character at lin ...
- VS2013中编译openssl的步骤和使用设置
一.VS2013中编译openssl的步骤 版本号:openssl-1.0.1e 1.下载 OpenSSL http://www.openssl.org/,并解压到d:\openssl-1.0.1e目 ...
- openwrt页面显示问题修改
页面显示错误如下: 在不应该的位置显示了这个,查看配置文件: config igmpproxy option quickleave '1' config phyint o ...
- [C]字符串行为
未事先分配长度的字符串变量声明,占用内存空间是这个字符串长度 + 1,1用于保存\0结束标识 #include <stdio.h> #include <stdlib.h> #i ...
- 微信小程序UI组件--Lin UI
地址:http://doc.mini.7yue.pro/ Lin UI 是基于 微信小程序原生语法 实现的组件库
- 清北学堂 清北-Day3-R2-打架 (fight)
题目描述 LYK有 \(n\) 个小朋友排成一排.第 \(i\) 个小朋友的战斗力是 $ a_i $,且他们的战斗力互不相同. 战斗力高的会打败战斗力低的. LYK想恶搞这些小朋友们,具体地,它有 \ ...
- C语言学习及应用笔记之三:C语言const关键字及其使用
在C语言程序中,const关键字也是经常会用到的一个关键字,那么使用const关键字的目的是什么呢?事实上,在程序中使用const关键字的主要目的就是为了向使用者传递设计者的一些意图. 事实上,无论我 ...
- selenium+python之 辨识alert、window以及操作
1.分辨 首先区别下alert.window和伪装对话框: alert,浏览器弹出框,一般是用来确认某些操作.输入简单的text或用户名.密码等,根据浏览器的不同,弹出框的样式也不一样,不过都是很简单 ...