第一章:模型层model layer
1.模型和字段
(1)基本的原则如下:
每个模型在Django中的存在形式为一个Python类
每个模型都是django.db.models.Model的子类
模型的每个字段(属性)代表数据表的某一列
Django将自动为你生成数据库访问API
(2)模型字段fields
Django不允许下面两种字段名:
与Python关键字冲突。这会导致语法错误。例如:
class Example(models.Model): pass = models.IntegerField() # 'pass'是Python保留字!
字段名中不能有两个以上下划线在一起,因为两个下划线是Django的查询语法。例如:
class Example(models.Model): foo__bar = models.IntegerField() # 'foo__bar' 有两个下划线在一起!
(3)常用字段类型
字段类型的作用:
决定数据库中对应列的数据类型(例如:INTEGER, VARCHAR, TEXT)
HTML中对应的表单标签的类型,例如<input type=“text” />
在admin后台和自动生成的表单中最小的数据验证需求
这里有如何上传文件和图片的方法:
1.FileField:
2.ImageField
3.FilePathField
4.UUIDField:
2.关系类型字段
一、多对一(ForeignKey)
二、多对多(ManyToManyField)
三、一对一(OneToOneField)
字段的参数:null,blank,default,help_text,primary_key,unique
3.多对多中间表详解
一、默认中间表
二、自定义中间表
三、使用中间表
4.模型的元数据Meta
强调:每个模型都可以有自己的元数据类,每个元数据类也只对自己所在模型起作用。
5.模型的继承
一、 抽象基类:
二、 多表继承
三、 代理模型
四、 多重继承
6.用包来组织模型
7.查询操作
查询操作是Django的ORM框架中最重要的内容之一。
一、创建对象
二、保存对象
1. 保存外键和多对多字段
三、检索对象
1. 检索所有对象
2. 过滤对象
3. 检索单一对象
4. 其它QuerySet方法
5. QuerySet使用限制
6. 字段查询
7. 跨越关系查询
8. 使用F表达式引用模型的字段
9. 主键的快捷查询方式:pk
10. 在LIKE语句中转义百分符号和下划线
11. 缓存与查询集
四、使用Q对象进行复杂查询
五、比较对象
六、删除对象
七、复制模型实例
八、批量更新对象
九、关系的对象
1. 一对多(外键)
2. 多对多
3. 一对一
4. 反向关联是如何实现的?
5. 通过关联对象进行查询
十、使用原生SQL语句
8.查询集API
一、QuerySet何时被提交
二、QuerySet
三、返回新QuerySets的API
1. filter()
2. exclude()
4. order_by()
12. all()
9.不返回QuerySets的API
1. get()
2. create()
6. count()
11. first()
15. update()
16. delete()
10.字段查询参数及聚合函数
1. exact
3. contains
5. in
10. startswith
12. endswith
聚合函数
5. Count
6. Max
7. Min
第一章:模型层model layer的更多相关文章
- 第一章:模型层model layer -- Django从入门到精通系列教程
该系列教程系个人原创,并完整发布在个人官网刘江的博客和教程 所有转载本文者,需在顶部显著位置注明原作者及www.liujiangblog.com官网地址. 题外话: Django的教程写到这里,就进入 ...
- 模型层model layer
题外话: Django的教程写到这里,就进入了整体的第二部分,也是最关键的部分.此时有一个问题必须想清楚,那就是,以项目带动内容还是以参考书目的方式展开?为此,我考虑了很久. 我在开始学习Django ...
- thinkphp模型层Model、Logic、Service讲解
thinkphp模型层Model.Logic.Service讲解 时间:2014-08-24 15:54:56 编辑:一切随缘 文章来源:php教程网 已阅读:771 次 js特效 ...
- 计算机网络自顶向下方法第3章-传输层 (Transport Layer).2
3.5 面向连接的运输: TCP 3.5.1 TCP连接 TCP是因特网运输层的面向连接的可靠的运输协议. TCP连接提供全双工服务(full-duplex service). TCP连接是点对点的连 ...
- 计算机网络自顶向下方法第3章-传输层 (Transport Layer).1
3.1 概述和运输层服务 运输层协议为运行在不同主机上的应用进程之间提供了逻辑通信(logic communication)功能. 3.1.1 运输层和网络层的关系 网络层提供了主机之间的逻辑通信,而 ...
- 64、django之模型层(model)--建表、查询、删除基础
要说一个项目最重要的部分是什么那铁定数据了,也就是数据库,这篇就开始带大家走进django关于模型层model的使用,model主要就是操纵数据库不使用sql语句的情况下完成数据库的增删改查.本篇仅带 ...
- django之模型层(model)--建表、查询、删除基础
要说一个项目最重要的部分是什么那铁定数据了,也就是数据库,这篇就开始带大家走进django关于模型层model的使用,model主要就是操纵数据库不使用sql语句的情况下完成数据库的增删改查.本篇仅带 ...
- odoo12从零开始:三、2)odoo模型层
前言 上一篇文章(创建你的第一个应用模块(module))已经大致描述了odoo的模型层(model)和视图层(view),这一篇文章,我们将系统地介绍有关于model的知识,其中包括: 1.模型的类 ...
- 传输层-Transport Layer(下):UDP与TCP报头解析、TCP滑动窗口、TCP拥塞控制详解
第六章 传输层-Transport Layer(下) 上一篇文章对传输层的寻址方式.功能.以及流量控制方法做了简短的介绍,这一部分将介绍传输层最重要的两个实例:TCP协议和UDP协议,看一看之前描述的 ...
随机推荐
- Celery ---- 分布式队列神器 ---- 入门
原文:http://python.jobbole.com/87238/ 参考:https://zhuanlan.zhihu.com/p/22304455 Celery 是什么? Celery 是一个由 ...
- as3 区别中文 英文 数字
1)英文a-z是65-90,A-Z是97-112 2)数字是0-9是,48-57 3)上万的都是中文字符 var str:String = "hello world! 你好世界! 88!&q ...
- iphone splash screen
https://developer.apple.com/library/ios/documentation/General/Reference/InfoPlistKeyReference/Articl ...
- heat 用法 示例
heat.exe dir "./SampleFolder" -cg Files -dr INSTALLDIR -gg -g1 -sf -srd -var "var.Tar ...
- ready 事件 DOM(文档对象模型) 已经加载....
定义和用法 当 DOM(文档对象模型) 已经加载,并且页面(包括图像)已经完全呈现时,会发生 ready 事件. 由于该事件在文档就绪后发生,因此把所有其他的 jQuery 事件和函数置于该事件中是非 ...
- tomcat的catalina.out日志文件过大
今天发现一个服务器的/opt目录数据过大,最后发现是tomcat中的catalina.out日志过大引起的 用du命令查看opt下一层的数据文件大小 [root@ccssapportalp opt]# ...
- 值得推荐的C/C++开源框架和库
值得推荐的C/C++开源框架和库 转自:http://www.cnblogs.com/lidabo/p/5514155.html - 1. Webbench Webbench是一个在Linux下 ...
- 八月(The Summer is Gone)观后感
第一次看到这部电影时觉得很亲近,黑白画面,国企改革的背景,浓浓的儿时画面感,原谅我只是一个三十不到的人,可能我比较早熟,对八九十年代还有些记忆,更早以前也通过电视.音乐.书籍等了解过一些,而那些听过又 ...
- 【转】oracle 体系结构
前几天面试的时候面试官才问过我Oracle的体系结构,让我在一张白纸上画出来.回头想想当时答得还不错,大部分内容都描述出来了,呵呵,刚才在网上看到一篇讲解ORACLE体系结构的文章,觉得不错,转过来存 ...
- Oracle免客户端InstantClient安装使用
正常情况下,用PL/SQL等软件连接Oracle,需要安装Oracle客户端软件,一般安装oracle客户端差不多需要2G左右的硬盘空间,但如果我们仅仅是连接数据库进行查询和执行一些相应的语句而不进行 ...