常用查询字段常用类型与模型关系表

知识点:

  1. 常用的查询

  2. Field的常用参数

  3. 常用的模型字段类型

常用的查询

获取所有记录:
rs = User.objects.all()
获取第一条数据:
rs = User.objects.first()
获取最后一条数据:
rs = User.objects.last()
根据参数提供的条件获取过滤后的记录:
rs = User.objects.filter(name='xiaoming')
注意:filter(**kwargs)方法:根据参数提供的提取条件,获取一个过滤后的QuerySet。
排除name等于xiaoming的记录:
rs = User.objects.exclude(name='xiaoming')
获取一个记录对象:
rs = User.objects.get(name='xiaoming')
注意:get返回的对象具有唯一性质,如果符合条件的对象有多个,则get报错!
对结果排序order_by:
rs = User.objects.order_by('age')
多项排序:
rs = User.objects.order_by('age','id')
逆向排序:
rs = User.objects.order_by('-age')
将返回来的QuerySet中的Model转换为字典
rs = User.objects.all().values()
获取当前查询到的数据的总数:
rs = User.objects.count()
#查询对象的条件
查找对象的条件的意思是传给以上方法的一些参数。相当于是SQL语句中的where语句后面的条件,语法为字段名__规则,以下将对这些规则进行说明:
exact 相当于等于号:
rs = User.objects.filter(name__exact='xiaoming')
iexact:跟exact,只是忽略大小写的匹配。
contains 包含:
rs = User.objects.filter(name__contains='xiao')
icontains 跟contains,唯一不同是忽略大小写。
startwith 以什么开始:
rs = User.objects.filter(name__startswith='xiao')
istartswith:同startswith,忽略大小写。
endswith:同startswith,以什么结尾。
iendswith:同istartswith,以什么结尾,忽略大小写。
in 成员所属:
rs = User.objects.filter(age__in=[18,19,20])
gt 大于:
rs = User.objects.filter(age__gt=20)
gte 大于等于:
rs = User.objects.filter(age__gte=20)
lt 小于:
rs = User.objects.filter(age__lt=20)
lte 小于等于:
rs = User.objects.filter(age__lte=20)
range 区间:
rs = User.objects.filter(age__range=(18,20))
isnull 判断是否为空:
rs = User.objects.filter(country__isnull=True)
切片:
rs = User.objects.all()[:2]
注意:不能使用负数作为切片。

Field的常用参数

primary_key: 指定是否为主键。

unique: 指定是否唯一。

null: 指定是否为空,默认为False。

blank: 等于True时form表单验证时可以为空,默认为False。

default: 设置默认值。

DateField.auto_now: 每次修改都会将当前时间更新进去,只有调用Model.save()方法才会调用,QuerySet.update方法将不会调用。这个参数只是Date和DateTime以及Time类才有的。

DateField.auto_now_add: 第一次添加进去,都会将当前时间设置进去。以后修改,不会修改这个值

常用的模型字段类型

  1. IntegerField : 整型,映射到数据库中的int类型。

  2. CharField: 字符类型,映射到数据库中的varchar类型,通过max_length指定最大长度。

  3. TextField: 文本类型,映射到数据库中的text类型。

  4. BooleanField: 布尔类型,映射到数据库中的tinyint类型,在使用的时候,传递True/False进去。如果要可以为空,则用NullBooleanField。

  5. DateField: 日期类型,没有时间。映射到数据库中是date类型,在使用的时候,可以设置DateField.auto_now每次保存对象时,自动设置该字段为当前时间。设置DateField.auto_now_add当对象第一次被创建时自动设置当前时间。

  6. DateTimeField: 日期时间类型。映射到数据库中的是datetime类型,在使用的时候,传递datetime.datetime()进去。

例子

class Ftest(models.Model):
   name = models.CharField(max_length=30)
   age = models.IntegerField()
   note = models.TextField()
   gender = models.BooleanField(default=True)
   create_time = models.DateField(auto_now_add=True)
   update_time = models.DateTimeField(auto_now=True)

1,查看数据库里面的数据。

2,使用常用的查询字段。

3,查看结果

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

知识要点:模型表关系的实现

一对多表关系

在Mysql中一对多是通过外键实现的,在django模型中通过ForeignKeyfield类型实现。

一对一表关系

在Mysql中一对一是通过外键加唯一键实现的,在django模型中通过OneToOneField类型实现。

多对多表关系

在Mysql中多对多是通过中间表外键加联合唯一键实现的,在django模型中通过ManyToManyField类型实现。中间表模型会自动帮我们创建好。

例子:
class Department(models.Model):
  d_id = models.AutoField(primary_key=True)
  d_name = models.CharField(max_length=30)
  def __str__(self):
      return 'Department<d_id=%s,d_name=%s>'%(
          self.d_id,self.d_name
      )

class Student(models.Model):
  s_id = models.AutoField(primary_key=True)
  s_name = models.CharField(max_length=30)
  department = models.ForeignKey('Department')
  course = models.ManyToManyField('Course')
  def __str__(self):
      return 'Student<s_id=%s,s_name=%s>'%(
          self.s_id,self.s_name
      )


class Course(models.Model):
  c_id = models.AutoField(primary_key=True)
  c_name = models.CharField(max_length=30)
  def __str__(self):
      return 'Course<c_id=%s,c_name=%s>'%(
          self.c_id,self.c_name
      )

class Stu_detail(models.Model):
  s_id = models.OneToOneField('Student')
  age = models.IntegerField()
  gender = models.BooleanField(default=1)
  country = models.CharField(max_length=30,null=True)
  def __str__(self):
      return 'Stu_detail<s_id=%s,age=%s,gender=%s,country=%s>'%(
          self.s_id,self.age,self.gender,self.country
      )

关系表中数据的操作

from .models import Department,Student,Course
def add_info(request):
    # d1 = Department(d_name='CC')
    # d1.save()
    # 一对多关系加内容
    # s1 = Student(s_name='xiaoming')
    # s1.department = d1
    # s1.save()
    # 多对多关系添加内容
    # c1 = Course(c_name='python')
    # s1 = Student.objects.first()
    # c1.save()
    # s1.course.add(c1)
    return HttpResponse('添加数据成功')

def search_info(request):
    rs = Student.objects.all()[0]
    # 一对多的查询
    print(rs.department)
    # 多对多的正向查询
    print(rs.course.all())
    cs = Course.objects.first()
    # 多对多反向查询
    print(cs.student_set.all())
    return HttpResponse('查询数据成功')

例子:

1,创建模型

2,映射模型文件

3,查看是否写入数据库

4,修改视图文件

5,查询

DJango 基础(7)的更多相关文章

  1. Python之路-(js正则表达式、前端页面的模板套用、Django基础)

    js正则表达式 前端页面的模板套用 Django基础 js正则表达式: 1.定义正则表达式 /.../  用于定义正则表达式 /.../g 表示全局匹配 /.../i 表示不区分大小写 /.../m ...

  2. Django 基础教程

    Django 基础教程 这是第一篇 Django 简介 »  Django 是由 Python 开发的一个免费的开源网站框架,可以用于快速搭建高性能,优雅的网站! 你一定可以学会,Django 很简单 ...

  3. python的django基础篇

    一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...

  4. Python学习(二十六)—— Django基础一

    转载自:http://www.cnblogs.com/liwenzhou/p/8258992.html 一.Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的 ...

  5. Django基础(一)

    Django基础(一) 知识预览 Django基本命令 二 路由配置系统(URLconf) 三 编写视图 四 Template 五 数据库与ORM admin的配置 一 什么是web框架? 框架,即f ...

  6. python3之Django基础篇

    一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...

  7. DJango 基础 (1)

    django基础 知识点: 基本认知 工具准备 新建项目 目录及文件说明 开发服务器 创建视图函数 新建应用(app) 1.基本认知 Django是用Python开发的一个免费开源的Web框架,可以用 ...

  8. Django基础和基本使用

    Django基础 Django是Python下的一款著名的Web框架 框架 任何语言进入到高级部分时,会有认证.session.http.连接数据库等等功能操作,没有框架时需要自己实现 框架 是整个或 ...

  9. {Django基础十之Form和ModelForm组件}一 Form介绍 二 Form常用字段和插件 三 From所有内置字段 四 字段校验 五 Hook钩子方法 六 进阶补充 七 ModelForm

    Django基础十之Form和ModelForm组件 本节目录 一 Form介绍 二 Form常用字段和插件 三 From所有内置字段 四 字段校验 五 Hook钩子方法 六 进阶补充 七 Model ...

  10. {Django基础九之中间件} 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证

    Django基础九之中间件 本节目录 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证 六 xxx 七 xxx 八 xxx 一 前戏 我们在前面的课程中已经学会了 ...

随机推荐

  1. CodeForce 517 Div 2. B Curiosity Has No Limits

    http://codeforces.com/contest/1072/problem/B B. Curiosity Has No Limits time limit per test 1 second ...

  2. js有哪些变态的语法?

    JS这个语言好是好,但是很多时候写起来太丑了,每次看大牛的代码的时候,妈妈都问我为什么跪着读代码,随着 ES 2015的普及我们可以写出很多可读性强且漂亮的代码,那么接下来就带着大家一块学习一下可以把 ...

  3. OSS阿里云上传文件 前端js下载url跨域问题

    场景: 1.后端上传文件至阿里云OSS,返回得到一个URL. 2.前端用这个URL下载文件,ajax请求异常:No 'Access-Control-Allow-Origin' header is pr ...

  4. MySQL Key值(PRI, UNI, MUL)的含义

    PRI主键约束: UNI唯一约束: MUL可以重复. 参考:http://www.cnblogs.com/licheng/archive/2010/10/16/1852938.html

  5. commit lint规范化团队git提交信息

    一.快速提交符号angular编码规范的提交信息 1.命令行中安装commitizen: npm install -g commitizen commitizen init cz-convention ...

  6. Docker容器常用命令

    容器是镜像的一个运行实例.两者不同的是,镜像是静态的只读文件,而容器带有运行时需要的可写文件层. 一.创建容器 1.新建容器 docker create:新建一个容器 create命令命令支持的选项十 ...

  7. 基于MNIST数据集使用TensorFlow训练一个包含一个隐含层的全连接神经网络

    包含一个隐含层的全连接神经网络结构如下: 包含一个隐含层的神经网络结构图 以MNIST数据集为例,以上结构的神经网络训练如下: #coding=utf-8 from tensorflow.exampl ...

  8. 爬虫:输入网页之后爬取当前页面的图片和背景图片,最后打包成exe

    环境:py3.6 核心库:selenium(考虑到通用性,js加载的网页).pyinstaller 颜色显示:colors.py colors.py  用于在命令行输出文字时,带有颜色,可有可无. # ...

  9. WPF 去掉Drag a column header here to group by that column

    <dxg:GridControl.View> <dxg:TableView x:Name="view" ShowGroupPanel="False&qu ...

  10. gentoo 建立本地软件库并安装软件 Custom repository

    参考 Handbook:AMD64/Portage/CustomTree https://wiki.gentoo.org/wiki/Handbook:AMD64/Portage/CustomTree# ...