一、今日内容总结:

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模板语法的更多相关文章

  1. python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)

    一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...

  2. 巨蟒python全栈开发django7:多表增加和查询

    1.回顾内容&&补充 补充1: 补充2: 这个选择的是第二个解释器. 选择第一个的话,只是针对当前的项目,如果再开新项目的话,需要重新下载安装相关的包. 点击保存,因为我们注释掉了,创 ...

  3. django模型层之多表操作 增删改查

    多表操作之创建模型 这边以书为中心创建一个模型 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是一对一的关系(on ...

  4. Django学习笔记--数据库中的单表操作----增删改查

    1.Django数据库中的增删改查 1.添加表和字段 # 创建的表的名字为app的名称拼接类名 class User(models.Model): # id字段 自增 是主键 id = models. ...

  5. $Django 多表操作(增删改查,基于双下划线,对象的查询) 在Python脚本中调用Django环境

    在Python脚本中调用Django环境. import osif __name__ == '__main__': os.environ.setdefault("DJANGO_SETTING ...

  6. python全栈开发 * 表格标签 表单标签 css 引入方式 * 180807

    html部分 一.表格标签<table> 1.一个表格<table>由每行<tr>组成的,每行是由<td>组成的. 注意: 一个表格是由行组成的(行是由 ...

  7. python 全栈开发,Day101(redis操作,购物车,DRF解析器)

    昨日内容回顾 1. django请求生命周期? - 当用户在浏览器中输入url时,浏览器会生成请求头和请求体发给服务端 请求头和请求体中会包含浏览器的动作(action),这个动作通常为get或者po ...

  8. python 全栈开发,Day8(文件操作)

    一.文件操作流程 文件以什么编码存储的,就以什么编码打开 参数: 1.文件路径 2.编码方式,encode 3.执行动作(打开方式):只读,只写,追加,读写,写读... 打开一个已经存在的文件 f = ...

  9. python 全栈开发,Day71(模型层-单表操作)

    昨日内容回顾 1. {% include '' %} 2. extend base.html: <html> ..... ..... ..... {% block content%} {% ...

随机推荐

  1. ubuntu html5开发工具brackets

    Brackets 是一款使用 HTML,CSS,JavaScript 创建的开源的针对 Web 开发的编辑器.实时预览,快速编辑,跨平台,可扩展,开源,让 Brackets 成为一款非常优秀的编辑器. ...

  2. OpenStack实践系列⑥构建虚拟机实例

    OpenStack实践系列⑥构建虚拟机实例 四.创建一台虚拟机图解网络,并创建一个真实的桥接网络 创建一个单一扁平网络(名字:flat),网络类型为flat,网络适共享的(share),网络提供者:p ...

  3. Python2018-列表的相关操作

    列表中存放的数据是可以进行修改的,比如"增"."删"."改" .“查” "增"-----append, extend, ...

  4. ASP.NET MVC5高级编程 之 模型

    1. 为MVC Music Store建模 Models文件夹(右击) --> 添加 --> 类 为类添加对应的属性: public class Album { public virtua ...

  5. php 汉字首字母和全拼

    <?php/** *+------------------------------------------------------ * PHP 汉字转拼音 *+----------------- ...

  6. windows被入侵检测

    1.net user 查看当前有哪些用户 2.net localgroup administrators 查询administrators最高权限组有哪些用户 3.net user administr ...

  7. C# Winform控件对透明图片重叠时导致图片不透明的解决方法(转)

    在Winform中如果将一个透明图片放在窗体上能正常显示透明,但是如果将该图片放在另一个控件上会导致不能显示透明效果. 解决这种情况,可以采取在控件上使用GDI+绘画出透明图片. 这里我们就以一个pi ...

  8. 锤子科技"临死前"被"接盘" ,内部人士爆料已改签今日头条母公司

    就在昨天,据据锤子科技内部人士透露,部分锤子科技员工在昨天已经接到了相关的临时通知,要求改签劳动合同至今日头条的母公司——字节跳动.至于这是锤子科技真正再度复活还是借尸还魂都不重要,重要的是,作为忠实 ...

  9. 安卓易学,爬坑不易—腾讯老司机的RecyclerView局部刷新爬坑之路

    前言 安卓开发者都知道,RecyclerView比ListView要灵活的多,但不可否认的里面的坑也同样埋了不少人.下面让我们看看腾讯开发工程师用实例讲解自己踩坑时的解决方案和心路历程. 话说有图有真 ...

  10. 银联支付java版

    注:本文来源于:<  银联支付java版    > 银联支付java版 2016年09月18日 15:55:20 阅读数:2431 首先去银联官网注册测试支付账户   下载对应的demo[ ...