一.数据库相关设置

配置ORM的loggers日志:

# 配置ORM的loggers日志
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console': {
'level': 'DEBUG',
'class': 'logging.StreamHandler',
},
},
'loggers': {
'django.db.backends': {
'handlers': ['console'],
'propagate': True,
'level': 'DEBUG',
},
}
}

二.单表简单操作

1.增

方式一:
user.objects.create(name='wangke', age=10, birthday='2010-01-01')

方式二:
user = User(name='wangke', age=25, birthday='2010-06-01')
user.save()

2.删

方式一:
User.objects.filter(name='wangke').delete()

方式二:
user = User.object.filter(name='wangke').first()
user.delete()

3.改

方式一:
User.objects.filter(name='wangke').update(name='wk') 方式二:
users = User.objects.filter(name='wangke')
for user in users:
user.name = 'wk'
user.save()

4.查

方式一:
users = User.objects.filter(name='wangke')
# 操作的结果是一个list 方式二:
user = User.objects.get(id=1)
# 只能操作有且只有一条数据的记录,否则会报错

三.单表操作函数

1. all():查询所有结果,结果是一个list,只支持正向索引取值[i],支持索引切片[m:n]

2.filter(**kwargs):查询满足条件的所有结果,结果是一个list

3.get(**kwargs):查询满足条件的唯一对象obj,查询结果不为obj则抛出异常

4.exclude(**kwargs):查询满足条件的对立面的所有结果list(相当于条件取反)

5.order_by(*field):查询按照指定字段(field)进行排序后的所有结果

6.reverse():反转排序查询的所有结果list

7.count():统计返回查询结果list的长度

8.first():返回查询结果中的第一个对象obj

9.last():返回查询结果中的最后一个对象obj

10.exists():判断查询结果是否存在,值为布尔值

11.values(*field):按照指定字段们进行查询,返回存放包含字段们的字典的列表list

12.values_list(*field):按照指定字段们进行查询,返回存放数据的元组的列表list

13.distinct():从查询结果中剔除重复字段(一般和values结合使用)

四.模糊查询

#都是在filter中进行的操作

# 整型相关
age__exact = 8 # 确切匹配8,相当于age=8
age__in = [8,10] # 8或10
age__gt = 8 # 大于8
age__gte = 8 # 大于等于8
age__lt = 8 # 小于8
age__lte = 8 # 小于等于8
age__range = [8,10] # 8到10之间
age__isnull = 0 # 值为0:is not null,值为1:is null # 字符串相关
name__startswith # 后方模糊匹配,以什么为开头
name__endswith # 前方模糊匹配,以什么结尾
name__contains # 前后方均模糊匹配,包含什么
name__reges # 正则匹配,使用正则表达式
name__istartswith # 不区分大小写后方模糊匹配(i开头就是不区分大小写) # 时间相关
birthday__year=2008 # 时间年份模糊匹配

五.F查询

# 通过字段名获取可以直接做运算的查询结果
from django.db.models import F # 例1:
# 将id为1的记录的年龄加1
User.objects.filter(id=1).update(age=F('age')+1) # 例2:
# 查询id是年龄1/4的结果
users = User.objects.filter(id=F('age')/4)

六.Q查询

# 完成逻辑运算方式的查询:与,或,非
from django.db.models import Q #1.与
User.objects.filter(Q(id=1) & Q(age=10))
# 默认就是与,例:User.objects.filter(id=1,age=10) #2.或
User.objects.filter(Q(id=1) | Q(id=10)) #3.非
User.objects.filter(~Q(id=1))

Django单表操作的更多相关文章

  1. django单表操作,增、删、改、查

    一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...

  2. django单表操作 增 删 改 查

    一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...

  3. Django学习笔记(7)——单表操作和多表操作

    单表操作 1,创建模型 创建名为book的APP,在book下的models.py中创建模型: from django.db import models # Create your models he ...

  4. web框架开发-Django模型层(1)之ORM简介和单表操作

    ORM简介 不需要使用pymysql的硬编码方式,在py文件中写sql语句,提供更简便,更上层的接口,数据迁移方便(有转换的引擎,方便迁移到不同的数据库平台)…(很多优点),缺点,因为多了转换环节,效 ...

  5. Django模型层-单表操作

    ORM介绍 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的 ...

  6. Django之模型层(单表操作)

    一.ORM简介 MVC和MTV框架中包含一个重要部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库. ORM是‘对象-关系- ...

  7. Django中模型层中ORM的单表操作

    ORM概念: MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员 ...

  8. day 46 Django 学习3 数据库单表操作以及反向解析

    前情提要: Django 已经学了不少了, 今天学习链接数据库的操作.以及相关的反向解析等 一:反向解析 1:反向解析模板层 跳转时设定url会随着前面的路由改变而改变         2:反向解析之 ...

  9. Django基础五之django模型层(一)单表操作

    一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人 ...

随机推荐

  1. laravel zh-CN

    位置: 调用:

  2. laravel 队列发送邮件

    批量处理任务的场景在我们开发中是经常使用的,比如邮件群发,消息通知,短信,秒杀等等,我们需要将这个耗时的操作放在队列中来处理,从而大幅度缩短Web请求和相应的时间.下面讲解下Laravel中队列的使用 ...

  3. laravel 容器注入的坑

    今天遍历添加数据时遇到个坑,哪位大神知道什么原因?? 起初的代码是这样的:(部分) public function addActive(Request $request, Activenorms $a ...

  4. bzoj1912 树形dp求直径(新写法),求直径的两端点

    通过回溯法可以求出直径的两个端点,同时注意有负权边的树求直径不可以用两次dfs来求,而必须用dp做 /* 分情况讨论问题 一条边也不加的情况,显然每条边要扫描两次, 该情况的答案是2(n-1) 只加一 ...

  5. servlet设置cookie

    Cookie cookie =new Cookie("user","黄花菜");//实例化一个Cookie对象 cookie.setMaxAge(7*24*60 ...

  6. map reduce程序示例

    map reduce程序示例 package test2; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop. ...

  7. 关于The specified Android SDK Build Tools version (26.0.2) is ignored, as it is below the minimum...

    今天将项目迁移到另一台笔记本,进行build出现以下问题,导致build失败 The specified Android SDK Build Tools version (26.0.2) is ign ...

  8. Kettle Spoon入门教程

    Kettle是一款国外开源的ETL工具,纯java编写,可以在Window.Linux.Unix上运行,数据抽取高效稳定.其中,Spoon是Kettle中的一个组件,其他组件有PAN,CHEF,Enc ...

  9. 【BZOJ3782】上学路线

    题解: 这个容斥以前做过 到i点的所有方案显然是个组合数 然后要减去不合法的方案数 我们可以考虑成减去到每个障碍点为第一次遇到的障碍然后之后乱走就可以了 因为模数不是质数,所以crt合并

  10. 3998: [TJOI2015]弦论

    题解: 每个点的size值就是这个从根-它出现的次数 如果相同只算一次就全部赋值为1就可以了 代码: #include <bits/stdc++.h> #define ll long lo ...