Django Model two
Django_model:
eg:
class XXXX(models.Model):
nid = models.AutoField(primary_Key=True)
name = models.CharField(max_length=32)
age = models.IntegerField()
authorDetail = models.OneToOneFiled(to='AuthorDetail')
author = models.ManyToManyField(to='Author')
publish = models.ForeignKeyField(to='Publish',to_field='nid')
字段的选项:
1.null 是否允许为空
2.blank 在表单填写的时候,是否可以不填
3.default 字段的默认值
4.primary_Key 是否为主键
5.unique 是否联合唯一
6.choice 多选
添加表记录:
普通字段:
1.publish_obj = Publish(name='人民出版社',city='北京')
publish_obj.save()
2.publish_obj = Publish.create(name='人民出版社',city='北京')
外键字段:
1.publish_obj = Publish.objects.filter(nid=1)[0]
Book.objects.create(title='python',publish=publish_obj)
2.Book.objects.create(title='python',publish_id=1)
关键点:book_obj.publish得到的就是这本书所对应出版社的对象,可以直接调用publish的属性
多对多字段:
book_obj.authors.add(author_obj1,author_obj2)
book_obj.authors.create() #创建并保存一个新的
book_obj.authors.all() #查询所有
book_obj.authors.remove() #将某个特定的对象删除
book_obj.authors.clear() #清空所有关联
两个删除方式,必须是多对多字段可以为空时,即null=True
查询相关method:
1.all() 查询所有
2.filter() 获取所有过滤后的queryset
3.get() 获取一个queryset,多余1个或者为0时报错
4.exclude() 所给筛选条件不匹配的对象
5.values() 返回需要的字段,以字典的形式,返回多个queryset
6.values_list() 返回需要的字段,以元祖的形式,返回一个queryset
7.order_by() 对查询结果排序
8.distinct() 从返回结果中删除重复的对象
9.reverse() 对查询结果反向排序
10.count() 返回匹配中的个数
11.firsr() 返回第一个
12.last() 返回最后一个
13.exists() 如果存在就返回True
14.only() 查找时只取所对应的字段,而不是取所有
15.defer() 和only相反
查询:
一对多:
正向:book_obj.publish.city
反向:publish_obj.book_set.title
一对一:
正向:author_mihon.authorDetail.telephone
反向:authorDetail_obj.author.name
多对对:
同一对一
聚合查询:
from django.db.models import Avg,Max,Min
Book.objects.all().agregate(avg_price=Avg('price')) -->{'avg_price':24.26}
Book.objects.all().agregate(Avg('price'),Max('price'),Min('price'))
{'price__avg': 34.35, 'price__max': Decimal('81.20'), 'price__min': Decimal('12.99')}
分组查询:
book_list = Book.objects.annotate(authorNum=Count('authors')) 统计每一本书的作者数
author_list = Author.objects.annotate(bookNum=Count('book')).filter(bookNum__gt=1) 统计出书不少于一本的作者
book_list = Book.objects.annotate(authorNum=Count('authors')).filter(authorNum__gt=1) 统计不止一个作者的书
book_list = Book.objects.annotate(authorNum=Count('authors')).order_by('authorNum') 根据每本书的作者数进行排序
F查询:
Book.objects.all().update(price=F('price')+30)
Q查询:
bookList = Book.objects.filter(Q(author_name='yuan')|Q(author_name='mihon'))
动态Q查询:
con = Q()
q1 = Q()
q1.connector = 'AND'
q1.children.append(('email',value_dict['email']))
q1.children.append(('password',value_dict['password']))
q2 = Q()
q2.connector = 'AND'
q2.children.append(('email',value_dict['email']))
q2.children.append(('email',value_dict['password']))
con.add(q1,'OR')
con.add(q2,'OR')
Django Model two的更多相关文章
- 【转】Django Model field reference学习总结
Django Model field reference学习总结(一) 本文档包含所有字段选项(field options)的内部细节和Django已经提供的field types. Field 选项 ...
- Django model字段类型清单
转载:<Django model字段类型清单> Django 通过 models 实现数据库的创建.修改.删除等操作,本文为模型中一般常用的类型的清单,便于查询和使用: AutoField ...
- Django:Model的Filter
转自:http://www.douban.com/note/301166150/ django model filter 条件过滤,及多表连接查询.反向查询,某字段的distinct 1.多表 ...
- Django model中 双向关联问题,求帮助
Django model中 双向关联问题,求帮助 - 开源中国社区 Django model中 双向关联问题,求帮助
- django 自定用户系统 以及 Django Model 定义语法
http://www.tuicool.com/articles/jMzIr2 django使用自己的用户系统 http://www.jianshu.com/p/c10be59aad7a Django ...
- tornado with MySQL, torndb, django model, SQLAlchemy ==> JSON dumped
现在,我们用torndo做web开发框架,用他内部机制来处理HTTP请求.传说中的非阻塞式服务. 整来整去,可谓之一波三折.可是,无论怎么样,算是被我做成功了. 在tornado服务上,采用三种数据库 ...
- Django Model field reference
===================== Model field reference ===================== .. module:: django.db.models.field ...
- Django model对象接口
Django model查询 # 直接获取表对应字段的值,列表嵌元组形式返回 Entry.objects.values_list('id', 'headline') #<QuerySet [(1 ...
- Django学习之四:Django Model模块
目录 Django Model 模型 MODEL需要在脑子里记住的基础概念 区分清楚,必须不能混淆的 class Meta 内嵌元数据定义类 简单model创建实例 数据源配置 接着通过models在 ...
- Django Model Form
ModelForm ModelForm结合了Form和Model,将models的field类型映射成forms的field类型,复用了Model和Model验证, 写更少的代码,并且还实现了存储数据 ...
随机推荐
- AJPFX浅析Java内存结构
1. Heap(堆):实例分配的地方,通过-Xms与-Xmx来设置2. MethodArea(方法区域):类的信息及静态变量. 对应是Permanet Generation, 通过-XX:PermSi ...
- 转:IOS程序之间的文件共享
原文 System-Declared Uniform Type Identifiers One of the common tasks that an iOS developer has to do ...
- 纪念Google Reader—Google Reader的最后一天
从2006年到今天,几乎每天我都会打开Google Reader,但是今天不一样,因为它是最后一天.心情有些依依不舍,像是与一位多年老朋友永别.因此我非常痛恨Google,先给你送来个好朋友,再从你身 ...
- dos 删除文件夹 rd
windows普通方法删除不了文件.文件夹?那么试试dos命令吧. rd的另外一个写法是rmdir,源自ReMakeDirectory.使用的方法也很简单:rd 文件夹名 即可,例如:rd test. ...
- datatables添加长按事件
长按事件 $.fn.longPress = function (fn) { var timeout = undefined; var $this = this; for (var i = 0; i & ...
- java校验maven下载的jar文件
有时候maven真的很坑! 有时候提示invalid LOC header (bad signat signature), 但又有时候什么都不提示,工程报错,情况有肯多中,不知道大家遇到过几种诡异的. ...
- github的pull Request使用
场景: teamA要一起做一个项目,选择用github管理自己的代码仓库,这时userA在github上新建了一个远程仓库,其他人需要通过pull request来实现提交.那么,问题来了,pull ...
- HDU 5501 The Highest Mark (贪心+DP,经典)
题意: 有n道题目,每道题目的初始分数为Ai,分数每分钟减少Bi,完成此题需要Ci分钟,问在t分钟内最多能获得多少分? 思路: 好题~ 如果没有B的话,就是一道裸的01背包的题目了.每道题目的得分为: ...
- 【UML】类图Class diagram(转)
http://blog.csdn.net/sds15732622190/article/details/48860711 前言 说到UML,相信大家就能立刻反应出其中的类图,为什么这么说呢,类图和用例 ...
- 设置DataGridView单元格的文本对齐方式
实现效果: 知识运用: DataGridViewCellStyle类的Alignment属性 //获取或设置DataGridView单元格内的单元格内容的位置 public DataGridV ...