[TOC=1,5]
>[success] # 表的三种对应方式
>[info] ## 一对一
* * * * *
<br>
>[info] ## 一对多 -- models.ForeignKey
~~~
class Book(models.Model):
name = models.CharField(max_length=32)
price = models.IntegerField()
pub_data = models.DateField(auto_now_add=True)
publish = models.ForeignKey('Publish')
class Publish(models.Model):
name = models.CharField(max_length=32)
city = models.CharField(max_length=32)
~~~
>[danger] ##### 增加
* 第一种方法通过真实的字段,也就是在_id添加
~~~
def index(request):
from cm import models
obj = models.Book.objects.create(
name = "c#",
price = 200,
pud_data = '2008-08-08',
publish_id= 1 # 这里保存的 关联表名_id
)
print(obj)
return HttpResponse('ok')
~~~
* 第二种通过对象添加,具体的操作是先查找出关联对象,把关联对象直接赋值給属性
>[danger] ##### 正向查
* 正向查找通过对象包含查找
~~~
def index(request):
from cm import models
obj = models.Book.objects.filter(name="python")
# 因为 books 和publish 关联,当book.publish ,是publish 库的对象
print(obj[0].publish.city)
return HttpResponse('ok')
~~~
>[danger] ##### 反向查找--反向指的是没有ForeignKey
* 通过查询反向数据库的对象,给到正向数据库
~~~
def index(request):
from cm import models
obj = models.Publish.objects.filter(name="理工")[0]
obj1 = models.Book.objects.filter(publish=obj).values("name")
print(obj1)
return HttpResponse('ok')
~~~
* 第二种通过set反查,也是获取反向数据库的对象,利用正向的名字_set
~~~
def index(request):
from cm import models
obj = models.Publish.objects.filter(name="理工")[0]
obj1 = obj.book_set.all()
print(obj1)
return HttpResponse('ok')
~~~
* 第三种直接属性双下滑下接字段,例如publish__name
~~~
def index(request):
from cm import models
obj = models.Book.objects.filter(publish__name="理工").values("name")
print(obj)
return HttpResponse('ok')
~~~
* * * * *
<br>
>[info] ## 多对多 -- ManyToManyFlied
>[danger] ### 利用ForeignKey 创建多对多
~~~
class HOST(models.Model):
uid = models.AutoField(primary_key=True)
host = models.CharField(max_length=32,db_index=True)
ip = models.GenericIPAddressField(max_length=32,db_index=True)
port = models.IntegerField()
b = models.ForeignKey('Business',to_field = 'id')
class Application(models.Model):
name = models.CharField(max_length=32)
class HostToApp(models.Model):
hobj = models.ForeignKey('HOST',to_field='uid')
aobj = models.ForeignKey('Application', to_field='id')
~~~
![](https://box.kancloud.cn/cceb07364cdaa78f1f99c2ac28a30a8c_561x562.png)
* * * * *
<br>
>[danger] ### 利用传统多对多
* 一个电影有多个导演,多个导演合作导了一部电影
~~~
class movies(models.Model):
name = models.CharField(max_length=20)
price = models.IntegerField()
authors = models.ManyToManyField('Author')
class Author(models.Model):
name = models.CharField(max_length=32)
~~~
创建出来第三个关联表
![](https://box.kancloud.cn/599ae96b300f0048039ee0741ec351e2_1099x403.png)
* * * * *
<br>
>[danger] ##### 查
通过中间桥的字段可以直接插第二个表
~~~
obj_movies = models.movies.objects.filter(id=2)
obj_author = models.Author.objects.all()
print(obj_movies[0].authors.values('name'))
~~~
>[danger] ##### 增加 -- add
* 给一组对象
~~~
obj_movies = models.movies.objects.create(name="大话西游", price="10")
obj_author = models.Author.objects.all()
obj_movies.authors.add(*obj_author)
~~~
* * * * *
* 给 id
~~~
obj = [1,2]
obj1 = models.movies.objects.filter(name="python")
obj1[0].authors.add(*obj)
~~~
* * * * *
>[danger] ##### 删除remove
删除和增加原理一样
~~~
obj1 = models.Book.objects.filter(name="python")
obj1[0].authors.remove(*obj)
return HttpResponse('ok')
~~~
- 网络原理
- 为搭建框架做准备
- 简单认识网路
- 自定义模拟网站案例
- 优化最终框架
- 数据存储 -- data
- 用户个人信息存储 -- User.txt
- 路由映射 -- routes
- 处理用户信息 -- routes_static.py
- 保存静态文件 -- static
- templates -- html 集中处理模块
- 首页 -- index.html
- 登陆 -- login.html
- 用户注册页面 -- register
- 日志模块 -- log.gua.txt
- 启动文件--server.py
- orm处理 -- model.py
- 日志模块 -- utils.py
- 两种数据库类型
- 传统数据库了解篇
- 前端快速入门
- JS简单使用入门
- css简单快速入门
- DJANGO
- virtualenv-创建虚拟环境
- 项目结构
- django-admin中文配置
- django-打印sql语句
- django-基础
- 认识MVC和MTV
- Django--初识
- Django--初识案例
- Django-FBV/CBV
- Django--常用input 交互
- Django-url
- Django-url.py 配置
- Django-include 使用
- Django-url name
- Django-ORM
- ORM-数据库配置
- ORM-model字段
- ORM-model字段解释
- ORM-字段选项
- ORM-查询
- ORM-四种常用查询方法
- ORM-三种获取数据
- ORM-其他查询方式
- ORM-条件查询双线
- ORM-Q和F条件使用
- ORM-三种数据库交互
- 案例 -- 一对多
- ORM-技巧/常见问题
- ORM-N+1 问题
- ORM-并发的处理
- ORM-数量查询、
- ORM-正向反向查询
- ORM-基础案例一
- ORM-基础一对多案例
- Django-templates
- Django-模板的继承
- Django-模板的过滤
- Django-自定义模板的过滤
- Django-cookie
- Django-cookies 装饰器
- Djang-session
- Django-CSRF
- Django-中间件 -- 后续了解
- Django- 缓存 -- 没有深入了解
- Django-form
- From-ajax
- form-内部验证处理
- form-属性
- form-常用的标签字段
- form-常用的下拉和选择
- form-widget速查
- Django-ajax序列化
- Django-多种ajax写法
- ajax-原生写法
- ajax-$写法
- ajax-ifram
- Django-ajax图片上传
- ajax-原始写法
- ajax-正常写法
- iframe+form
- 实战写法
- Django-常用自编写组件
- Django-双菜单组合搜索
- Django - 多菜单组合搜索
- Django-分页
- django-综合基础
- 综合基础-render
- django-admin
- admin-页面配置
- admin-字段配置
- admin-编辑页面
- admin-forms验证
- admin-创建抽象类
- django-验证码
- 验证码-第三方生成库
- 验证码-view.py使用
- 验证码-注意引入Monaco.ttf
- django-用户注册
- 注册-form 模块
- 注册-views 模块
- 注册-html模块
- 注册-model模块
- django-用户登录三种
- session登录
- form-session 写法
- view-写法
- Html-写法
- model-写法
- 继承类登录
- 外键关联登录
- django-简单的student 管理案例
- app-urls.py
- app-models.py配置
- admin-admin.py配置
- app-form.py 和数据库关联的写法
- app-FBV_views.py
- app-CBV_views.py
- templates-index.html
- django-博客系统
- APP目录-models.py 创建
- APP目录-基础展示数据分析
- APP目录-基础数据展示cls
- ListView
- DetailView
- FormView
- 额外功能拓建
- 添加文章搜索/用户文章查询功能
- 增加一个友情链接
- 增加一个评论模块
- App-利用Bootstrap4 搭建样式
- 项目crm
- 思维导图
- perfectCRM-项目名字
- settings.py-配置
- view.py-登陆/登出函数
- crm-app文件
- model.py-表的创建
- admin.py-注册后台
- view.py-视图层
- static-静态文件
- css
- bootstrap.min.css
- dashboard.css
- ie10-viewport-bug-workaround.css
- signin.css
- fonts
- imgs
- js
- jquery.js
- bootstrap.min.js
- holeder.js
- ie10-viewport-bug-workaround.js
- ie-emulation-modes-warning.js
- plugins
- html模板文件-templates
- crm
- index.html-首页模板