一、通过 ORM 向 DB 中增加数据

1、Entry.objects.create(属性=值,属性=值)
Entry:具体要操作的Model类

ex:
  Author.objects.create(name='zsf',age=85)

2、创建一个 Models 对象,通过对象的 save() 完成增加

ex:
  author = Author(names='laoshe',age=65)
  author.save()

3、使用字典构建属性,通过 save() 完成增加
dic = {
'属性1':'值1',
'属性2':'值2',
}

obj = Entry(**dic)
obj.save()

4、首先尝试获取,不存在就创建,可以防止重复

Author.objects.get_or_create(names='laoshe',age=65)

备注:前三种方法返回的都是对应的 object,最后一种方法返回的是一个元组,(object, True/False),创建时返回 True, 已经存在时返回 False

二、查询操作

通过 Entry.objects 调用查询接口

1、查询所有对象
语法:all()
用法:Entry.objects.all()
返回:QuerySet

ex:
  Author.objects.all()
  等同于:select * from index_author

返回结果:
<QuerySet [<Author: Author object>, <Author: Author object>, <Author: Author object>]>

2、查询指定列
语法:values('列1','列2',...)
用法:Entry.objects.values('列1','列2',...)
返回:QuerySet(返回一个包含数据的字典的queryset,而不是模型实例)

ex:
  Author.objects.values('names','age')
  等同于:select name,age from index_author

注意:
  values()可以用在所有的返回查询结果集的方法的后面

  Author.objects.all().values('names','age')

  <QuerySet [{'age': 65, 'names': 'ZhuZiqing'}, {'age': 68, 'names': 'laoshe'}, {'age': 59, 'names': 'MoYan'}]>

  

3、排序函数

语法:order_by('列1','列2')
用法:Entry.objects.order_by('-列1','列2')
默认的排序规则是升序
如果需要降序,则在列前添加一个 "-"
ex:
  1、Author.objects.order_by('age')
  2、Author.objects.all().order_by('-age');

4、对条件取反
语法:exclude()
用法:Entry.objects.exclude(条件)
ex:
  1、Author.objects.exclude(id=3)
  等同于:select * from author where not (id=3)
  2、Author.objects.exclude(id=3,age=85)
  等同于:select * from author where not (id=3 and age=85)

5、根据条件查询部分行数据(重难点)
方法:filter(参数)
用法:Entry.objects.filter(参数)
1、使用 Entry 中的属性作为查询参数
多个参数的话,使用 , 隔开,映射到sql语句上,是使用 and 来进行关联的
ex:
  1、Author.objects.filter(id=1)
  等同于:select * from author where id=1
  2、Author.objects.filter(id=1,name='莫言')
  等同于:select * from author where id=1 and name='莫言'
2、通过 Field Lookup(查询表达式)完成复杂条件的构建
查询表达式:每个查询表达式都是一个独立的查询条件,可以用在所有的有查询条件的位置处
  1、__contains(__icontains忽略大小写)
  作用:筛选出属性中包含指定关键字的记录(模糊查询)
  ex:
    Author.objects.filter(names__contains='ao')
    select * from author where names like '%ao%'

  2、__in

   作用:筛选出属性值在其中之一的记录
   ex:
    Author.objects.filter(id__in=[1,3])
      select * from author where id in (1,3)

  3、__lt
  作用:筛选出属性值小于指定值的记录
  4、__lte
  作用:筛选出属性值小于等于指定值的记录
  5、__gt
  作用:筛选出属性值大于指定值的记录
  6、__gte
  作用:筛选出属性值大于等于指定值的记录
  7、__startswith
  作用:筛选出以指定关键字开始的记录
  8、__endswith
  作用:筛选出以指定关键结尾的记录

6、查询只返回一条数据
语法:get(条件)
用法:Entry.objects.get(查询条件/表达式)
get和filter区别:

  参数:
    get 的参数只能是model中定义的那些字段,只支持严格匹配

    filter 的参数可以是字段,也可以是扩展的查询表达式,如in,contains等

  返回值:

    get 返回值是一个定义的model对象

     filter 返回值是一个新的queryset对象,然后可以对queryset在进行查询返回新的queryset对象,支持链式操作

  异常:

    get 只有一条记录返回的时候才正常,也就说明get的查询字段必须是主键或者唯一约束的字段,当返回多条记录或者是没有找到记录的时候都会抛出异常

    filter 有没有匹配的记录都可以,如果没有匹配的记录会返回一个空的queryset

三、修改数据

1、修改单个数据
  1、通过 get() 得到要修改的实体对象
  2、通过实体对象的属性修改属性值
  3、再通过实体对象的save()保存回数据库
ex:
  au = Author.objects.get(id=1)
  au.names = "老舍"
  au.age = 45
  au.save()

2、批量修改数据
调用查询结果集的 update() 完成批量修改
Entry.objects.all().update(属性=值,属性=值)

ex:
  Author.objects.all().update(age=75)

四、删除数据
调用实体对象/查询结果集的 delete() 即可

Person.objects.filter(name__contains="abc").delete()  # 删除名称中包含 "abc"的人

如果写成
people = Person.objects.filter(name__contains="abc")
people.delete()
效果也是一样的,Django实际只执行一条 SQL 语句。

Django 模型中的CRUD的更多相关文章

  1. 如何在Django模型中管理并发性 orm select_for_update

    如何在Django模型中管理并发性 为单用户服务的桌面系统的日子已经过去了 - 网络应用程序现在正在为数百万用户提供服务,许多用户出现了广泛的新问题 - 并发问题. 在本文中,我将介绍在Django模 ...

  2. Django模型中OneToOneField和ForeignKey的区别

    网上看到一篇讲解"Django模型中OneToOneField和ForeignKey区别" 的文章,浅显易懂; 可以把ForeignKey形象的类比为: ForeignKey是on ...

  3. 如何让django模型中的字段和model名显示为中文

    如何让django模型中的字段和model名显示为中文:在模型中加入class Meta即可 class People(models.Model): name = models.CharField(n ...

  4. django模型中的抽象类(abstract)

    首先介绍下django的模型有哪些属性:先看例子: Django 模型类的Meta是一个内部类,它用于定义一些Django模型类的行为特性.以下对此作一总结: abstract 这个属性是定义当前的模 ...

  5. Django 模型中自定义Manager和模型方法

    1.自定义管理器(Manager) 在语句Book.objects.all()中,objects是一个特殊的属性,通过它来查询数据库,它就是模型的一个Manager. 每个Django模型至少有一个m ...

  6. django模型中的关系对应

    显然,关系数据库的力量在于将表相互关联.Django提供了定义三种最常见的数据库关系类型的方法:多对一,多对多和一对一. 在说明之前,首先来理解一下这三个概念: 多对一: 两个集合a,b;集合a中的多 ...

  7. django 模型中 class Meta 内 各种属性的用法

    Django 模型类的Meta是一个内部类,它用于定义一些Django模型类的行为特性.下面对此作一总结: abstract 这个属性是定义当前的模型类是不是一个抽象类.所谓抽象类是不会相应数据库表的 ...

  8. Django 模型中FileField字段

    FileField¶ class FileField([upload_to=None, max_length=100, **options])¶ 一个上传文件的字段. 注意 FileField字段不支 ...

  9. 在 django模型中封装元组和字典, 字段中使用chioce参数实现数据的一一对应

    一.models.py中 class OrderInfo(BaseModel): '''订单模型类''' # 封装一个字典, 便于在视图中取值, 进行比对 PAY_METHODS = { : &quo ...

随机推荐

  1. Html5 学习笔记 【PC固定布局】 实战7 机票预订页面

    最终实际效果: HTML代码: <!DOCTYPE html> <html lang="zh-cn"> <head> <meta char ...

  2. 开启关闭mysql服务

    1.Windows下 启动服务 mysqld --console 或 net start mysql 关闭服务 mysqladmin -uroot shudown 或 net stop mysql   ...

  3. 【awk】 处理多个文件

    处理多个文件: 1. 可以在代码中指定读取某个文件, 其他的用命令行输入           while ( geline < "file.txt" > 0 ) {   ...

  4. 将本地图片数据制作成内存对象数据集|tensorflow|手写数字制作成内存对象数据集|tf队列|线程

      样本说明: tensorflow经典实例之手写数字识别.MNIST数据集. 数据集dir名称 每个文件夹代表一个标签label,每个label中有820个手写数字的图片 标签label为0的文件夹 ...

  5. UVA1608_Non-boring sequences

    Non-boring sequences 大致题意: 给你一个字符串,问你他的任一子串是否都包含一个唯一的字符 思路: 看似简单,实际一丁点思路都没有 后面看汝佳的讲解都看了好长时间 大概思路就是,先 ...

  6. 2019PhpStrom注册码(破解)+汉化(中文)

    PhpStrom破解使用 IDEA激活码:  https://app.yinxiang.com/fx/bd2158ab-fea3-4382-966f-eaf54f5a4de7 phpStorm使用说明 ...

  7. 深度学习大规模MIMO中的功率分配

    摘要-本文使用深度学习的方法在大规模MIMO网络的下行链路中执行max-min和max-prod功率分配.更确切地说,与传统的面向优化的方法相比,训练深度神经网络来学习用户设备(UE)的位置和最优功率 ...

  8. 彻底干掉恶心的 SQL 注入漏洞, 一网打尽!

    来源:b1ngz.github.io/java-sql-injection-note/ 简介 文章主要内容包括: , name); 还有一些情况,比如 order by.column name,不能使 ...

  9. poj3252 Round Numbers(数位dp)

    题目传送门 Round Numbers Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 16439   Accepted: 6 ...

  10. SpringMVC学习(7):格式化显示

    在系列(6)中我们介绍了如何验证提交的数据的正确性,当数据验证通过后就会被我们保存起来.保存的数据会用于以后的展示,这才是保存的价值.那么在展示的时候如何按照要求显示?(比如:小数保留一定的位数,日期 ...