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的更多相关文章

  1. 【转】Django Model field reference学习总结

    Django Model field reference学习总结(一) 本文档包含所有字段选项(field options)的内部细节和Django已经提供的field types. Field 选项 ...

  2. Django model字段类型清单

    转载:<Django model字段类型清单> Django 通过 models 实现数据库的创建.修改.删除等操作,本文为模型中一般常用的类型的清单,便于查询和使用: AutoField ...

  3. Django:Model的Filter

    转自:http://www.douban.com/note/301166150/   django model filter 条件过滤,及多表连接查询.反向查询,某字段的distinct   1.多表 ...

  4. Django model中 双向关联问题,求帮助

    Django model中 双向关联问题,求帮助 - 开源中国社区 Django model中 双向关联问题,求帮助

  5. django 自定用户系统 以及 Django Model 定义语法

    http://www.tuicool.com/articles/jMzIr2 django使用自己的用户系统 http://www.jianshu.com/p/c10be59aad7a Django ...

  6. tornado with MySQL, torndb, django model, SQLAlchemy ==> JSON dumped

    现在,我们用torndo做web开发框架,用他内部机制来处理HTTP请求.传说中的非阻塞式服务. 整来整去,可谓之一波三折.可是,无论怎么样,算是被我做成功了. 在tornado服务上,采用三种数据库 ...

  7. Django Model field reference

    ===================== Model field reference ===================== .. module:: django.db.models.field ...

  8. Django model对象接口

    Django model查询 # 直接获取表对应字段的值,列表嵌元组形式返回 Entry.objects.values_list('id', 'headline') #<QuerySet [(1 ...

  9. Django学习之四:Django Model模块

    目录 Django Model 模型 MODEL需要在脑子里记住的基础概念 区分清楚,必须不能混淆的 class Meta 内嵌元数据定义类 简单model创建实例 数据源配置 接着通过models在 ...

  10. Django Model Form

    ModelForm ModelForm结合了Form和Model,将models的field类型映射成forms的field类型,复用了Model和Model验证, 写更少的代码,并且还实现了存储数据 ...

随机推荐

  1. css3响应式图片

    响应式图片指用户代理根据输出设备的分辨率不同加载不同类型的图片,不会造成带宽的浪费. 同时,在改变输出设备类型或分辨率时,能及时加载对应类型的图片.   常用的实现方式: 1.用srcset和size ...

  2. java的三大特性之一继承概述

    0.继承-----注意事项 00.子类最多只能继承一个父类(指直接继承) 01.java所有的类都是Object的子类 02.JPK6.0中有202个包3777个类,接口,异常,枚举,注释和错误 03 ...

  3. cssText在js中写样式表兼容全部

    oDiv.style.cssText="width:100px;height:200px;";是前面的升级版(oDiv.style.width='200px';) <styl ...

  4. Cookie 没你不行

    Cookie 没你不行 Cookie 没你不行 前言: Cookie 是什么 起源 到底是什么? 使用场景 如何使用cookie Cookie 和http协议 (服务端操作cookie) Cookie ...

  5. Mandelbrot图像

      using System;using System.Collections.Generic;using System.Text; namespace ConsoleApplication3{    ...

  6. Oracle 11g 新特性 – HM(Hang Manager)简介

    在这篇文章中我们会对oracle 11g 新特性—hang 管理器(Hang Manager) 进行介绍.我们需要说明,HM 只在RAC 数据库中存在. 在我们诊断数据库问题的时候,经常会遇到一些数据 ...

  7. Raid 6与raid 5的区别

    RAID5和RAID6有下面几个区别: 1.冗余和数据恢复能力 RAID组级别 冗余及数据恢复能力 数据恢复策略 RAID 5 存在分散在不同条带上的奇偶校验数据 允许一块数据盘故障,并可通过奇偶校验 ...

  8. Controller接收处理json、xml格式数据

    1.RequestBody接收json格式的数据,并直接转为对象. User.java使用lombok依赖包 @Data @AllArgsConstructor @NoArgsConstructor ...

  9. mysql 速度检索

    授权GRANT ALL PRIVILEGES ON zabbix.* TO 'zabbix'@'127.0.0.1' IDENTIFIED BY 'zabbixpwd' WITH GRANT OPTI ...

  10. 2018.3.16 Ubuntu 解决中文乱码问题

    一.乱码的样子类似: °²Àï¿ü ÒÁ¸ñÀ³Ï£ÑÇ˹,°²Àï¿ü ÒÁ¸ñÀ³Ï£ÑÇ˹ 这种乱码称为Gedit中文乱码 打开部分Windows下的txt文本文件的时候,中文显示为乱码.但 ...