Django--models表操作
需求
models对表的增删改查
知识点
1、基础操作
1.1 增
方法一
1
models.Tb1.objects.create(c1='xx', c2='oo') #增加一条数据
1
2
dic = {'c1':'xx','c2':'oo'}
models.Tb1.objects.creat(**dic) #可以接受字典类型数据 **kwargs
form提交的数据就是字典类型,可以直接当做参数**dic传给models增加数据。
方法二
1
2
obj = models.Tb1(c1='xx', c2='oo')
obj.save()
1.2 查
1
models.Tb1.objects.get(id=123) # 获取单条数据,不存在则报错(不建议使用)
1
models.Tb1.objects.all() # 获取全部,它是一个Django的查询对象;取第一条.first();取列成字典.values('username');取列成列表.value_list()
1
models.Tb1.objects.filter(name='seven') # 获取指定条件的数据
1.3 删
1
models.Tb1.objects.filter(name='seven').delete() # 删除指定条件的数据
1.4 改
1
models.Tb1.objects.filter(name='seven').update(gender='0') # 将指定条件的数据更新,均支持 **kwargs
1
2
3
obj = models.Tb1.objects.get(id=1)
obj.c1 = '111'
obj.save() # 修改单条数据,不常用
2、进阶操作
2.1 获取个数
1
models.Tb1.objects.filter(name='seven').count()
2.2 大于,小于
1
2
3
models.Tb1.objects.filter(id__gt=1) # 获取id大于1的值,(两个双下划线)
models.Tb1.objects.filter(id__lt=10) # 获取id小于10的值
models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值
2.3 in
1
2
models.Tb1.objects.filter(id__in=[11, 22, 33]) # 获取id等于11、22、33的数据
models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in
2.4 contains
1
2
3
models.Tb1.objects.filter(name__contains="ven")
models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
models.Tb1.objects.exclude(name__icontains="ven")
2.5 range
1
models.Tb1.objects.filter(id__range=[1, 2]) # 范围bettwen and
2.6 其他类似
1
startswith,istartswith, endswith, iendswith,
2.7 order by
1
2
models.Tb1.objects.filter(name='seven').order_by('id') # asc,从小到大排列
models.Tb1.objects.filter(name='seven').order_by('-id') # desc,从大到小排列
2.8 limit 、offset
1
models.Tb1.objects.all()[10:20] #分页用
2.9 group by
1
2
3
from django.db.models import Count, Min, Max, Sum #个数,最小,最大,求和
models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num')) #annotate=grounp by,比如id为1的num列的个数
#SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"
详细
1、增
models.py
1
2
3
class SimpleModel(models.Model):
username = models.CharField(max_length=64)
password = models.CharField(max_length=64)
views.py
1
2
3
4
5
def index(request):
dic = {"username":"user1","password":"123"}
models.SimpleModel.objects.create(**dic)
obj= HomeForm.ImportForm(request.POST)
return render(request,'home/index.html',{'obj':obj})
2、查
1
2
3
4
5
6
7
8
9
10
11
12
def index(request):
ret = models.SimpleModel.objects.all()
print ret #[<SimpleModel: SimpleModel object>, ]对象的列表
print type(ret) #<class 'django.db.models.query.QuerySet'>
print ret.query #SELECT "id", "username","password" FROM "app01_simplemodel"
print models.SimpleModel.objects.all().values("username")
#[{'username': u'user1'}, {'username': u'user2'}, {'username': u'user3'}]
print models.SimpleModel.objects.all().values_list("id","username")
#[(1, u'user1'), (2, u'user2'), (3, u'user3')]
#正是form--select的格式
obj = HomeForm.ImportForm(request.POST)
return render(request,'home/index.html',{'obj':obj})
Django--models表操作的更多相关文章
- django models 数据库操作
django models 数据库操作 创建模型 实例代码如下 from django.db import models class School(models.Model): pass class ...
- Django—models相关操作
一.在django后台admin管理页面添加自己增加的表结构 通过终端命令:python3 manage.py makemigrations, python3 manage.py migrate 我们 ...
- Django多表操作
多表创建 创建模型 下面通过一个简单的图书管理系统,来阐述多表的创建和查询操作 在视图函数里里定义如下代码 from django.db import models class Book(models ...
- Django单表操作
一.数据库相关设置 配置ORM的loggers日志: # 配置ORM的loggers日志 LOGGING = { 'version': 1, 'disable_existing_loggers': F ...
- django models数据库操作
一.数据库操作 1.创建model表 基本结构 1 2 3 4 5 6 from django.db import models class userinfo(models.M ...
- Django Models 查询操作
1.准备数据表: from django.db import models class City(models.Model): name=models.CharField(max_length=32) ...
- django单表操作,增、删、改、查
一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...
- django单表操作 增 删 改 查
一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...
- Django分表操作、聚合及FQ方法
聚合 aggregate(*args, **kwargs) # 计算所有图书的平均价格 from django.db.models import Avg Book.objects.all().aggr ...
- $Django 多表操作(增删改查,基于双下划线,对象的查询) 在Python脚本中调用Django环境
在Python脚本中调用Django环境. import osif __name__ == '__main__': os.environ.setdefault("DJANGO_SETTING ...
随机推荐
- 奇怪吸引子---Rucklidge
奇怪吸引子是混沌学的重要组成理论,用于演化过程的终极状态,具有如下特征:终极性.稳定性.吸引性.吸引子是一个数学概念,描写运动的收敛类型.它是指这样的一个集合,当时间趋于无穷大时,在任何一个有界集上出 ...
- Gulan查询UI排布
遇到一个问题,如何在相对布局里把两个item放在同一行,而且高度一样呢? <RelativeLayout xmlns:android="http://schemas.android.c ...
- 安装redis监控
在修改登录中心的时候,数据存储在redis里面,需要对redis进行监控,使用的是Redis-Live 参考文章: http://www.nkrode.com/article/real-time-da ...
- 删除windows系统中以前的设备(比如以前的网卡)或驱动的方法
1.在“开始”菜单单击“运行”,然后在“运行”对话框中输入“CMD”命令打开命令提示符窗口:2.在提示符窗口中输入“Set devmgr_show_nonpresent_devices=1”并回车:3 ...
- Folder Recursion with C#
by Richard Carr, published at http://www.blackwasp.co.uk/FolderRecursion.aspx Some applications must ...
- linux 下 取进程占用内存(MEM)最高的前10个进程
# linux 下 取进程占用 cpu 最高的前10个进程ps aux|head -1;ps aux|grep -v PID|sort -rn -k +3|head # linux 下 取进程占用内存 ...
- CSS3学习笔记--transform基于原始数据(旋转木马实例)
参考链接:好吧,CSS3 3D transform变换,不过如此! transform-style:preserve-3d属性要在图片所在的容器(父元素)中定义,perspective定义在父子元素上 ...
- Strategy策略设计模式
1.策略模式和状态模式的区别和联系(本部分转载自:http://letscoding.cn/java%E4%B8%AD%EF%BC%8C%E7%8A%B6%E6%80%81%E6%A8%A1%E5%B ...
- iOS开发——项目实战总结&数据持久化分析
数据持久化分析 plist文件(属性列表) preference(偏好设置) NSKeyedArchiver(归档) SQLite 3 CoreData 当存储大块数据时你会怎么做? 你有很多选择,比 ...
- Ajax学习笔记(二)
二.prototype库具体解释 1.prototype库的使用 //导入下载好的prototype.js文件 <script type="text/javascript" ...
|
1
|
models.Tb1.objects.create(c1='xx', c2='oo') #增加一条数据 |
|
1
2
|
dic = {'c1':'xx','c2':'oo'}models.Tb1.objects.creat(**dic) #可以接受字典类型数据 **kwargs |
|
1
2
|
obj = models.Tb1(c1='xx', c2='oo')obj.save() |
|
1
|
models.Tb1.objects.get(id=123) # 获取单条数据,不存在则报错(不建议使用) |
|
1
|
models.Tb1.objects.all() # 获取全部,它是一个Django的查询对象;取第一条.first();取列成字典.values('username');取列成列表.value_list() |
|
1
|
models.Tb1.objects.filter(name='seven') # 获取指定条件的数据 |
|
1
|
models.Tb1.objects.filter(name='seven').delete() # 删除指定条件的数据 |
|
1
|
models.Tb1.objects.filter(name='seven').update(gender='0') # 将指定条件的数据更新,均支持 **kwargs |
|
1
2
3
|
obj = models.Tb1.objects.get(id=1)obj.c1 = '111'obj.save() # 修改单条数据,不常用 |
|
1
|
models.Tb1.objects.filter(name='seven').count() |
|
1
2
3
|
models.Tb1.objects.filter(id__gt=1) # 获取id大于1的值,(两个双下划线)models.Tb1.objects.filter(id__lt=10) # 获取id小于10的值models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值 |
|
1
2
|
models.Tb1.objects.filter(id__in=[11, 22, 33]) # 获取id等于11、22、33的数据models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in |
|
1
2
3
|
models.Tb1.objects.filter(name__contains="ven")models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感models.Tb1.objects.exclude(name__icontains="ven") |
|
1
|
models.Tb1.objects.filter(id__range=[1, 2]) # 范围bettwen and |
|
1
|
startswith,istartswith, endswith, iendswith, |
|
1
2
|
models.Tb1.objects.filter(name='seven').order_by('id') # asc,从小到大排列models.Tb1.objects.filter(name='seven').order_by('-id') # desc,从大到小排列 |
|
1
|
models.Tb1.objects.all()[10:20] #分页用 |
|
1
2
3
|
from django.db.models import Count, Min, Max, Sum #个数,最小,最大,求和models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num')) #annotate=grounp by,比如id为1的num列的个数 # |
1、增
models.py
|
1
2
3
|
class SimpleModel(models.Model): username = models.CharField(max_length=64) password = models.CharField(max_length=64) |
views.py
|
1
2
3
4
5
|
def index(request): dic = {"username":"user1","password":"123"} models.SimpleModel.objects.create(**dic) obj= HomeForm.ImportForm(request.POST) return render(request,'home/index.html',{'obj':obj}) |
2、查
|
1
2
3
4
5
6
7
8
9
10
11
12
|
def index(request): ret = models.SimpleModel.objects.all() print ret #[<SimpleModel: SimpleModel object>, ]对象的列表 print type(ret) #<class 'django.db.models.query.QuerySet'> print ret.query #SELECT "id", "username","password" FROM "app01_simplemodel" print models.SimpleModel.objects.all().values("username") #[{'username': u'user1'}, {'username': u'user2'}, {'username': u'user3'}] print models.SimpleModel.objects.all().values_list("id","username") #[(1, u'user1'), (2, u'user2'), (3, u'user3')] #正是form--select的格式 obj = HomeForm.ImportForm(request.POST) return render(request,'home/index.html',{'obj':obj}) |
Django--models表操作的更多相关文章
- django models 数据库操作
django models 数据库操作 创建模型 实例代码如下 from django.db import models class School(models.Model): pass class ...
- Django—models相关操作
一.在django后台admin管理页面添加自己增加的表结构 通过终端命令:python3 manage.py makemigrations, python3 manage.py migrate 我们 ...
- Django多表操作
多表创建 创建模型 下面通过一个简单的图书管理系统,来阐述多表的创建和查询操作 在视图函数里里定义如下代码 from django.db import models class Book(models ...
- Django单表操作
一.数据库相关设置 配置ORM的loggers日志: # 配置ORM的loggers日志 LOGGING = { 'version': 1, 'disable_existing_loggers': F ...
- django models数据库操作
一.数据库操作 1.创建model表 基本结构 1 2 3 4 5 6 from django.db import models class userinfo(models.M ...
- Django Models 查询操作
1.准备数据表: from django.db import models class City(models.Model): name=models.CharField(max_length=32) ...
- django单表操作,增、删、改、查
一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...
- django单表操作 增 删 改 查
一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...
- Django分表操作、聚合及FQ方法
聚合 aggregate(*args, **kwargs) # 计算所有图书的平均价格 from django.db.models import Avg Book.objects.all().aggr ...
- $Django 多表操作(增删改查,基于双下划线,对象的查询) 在Python脚本中调用Django环境
在Python脚本中调用Django环境. import osif __name__ == '__main__': os.environ.setdefault("DJANGO_SETTING ...
随机推荐
- 奇怪吸引子---Rucklidge
奇怪吸引子是混沌学的重要组成理论,用于演化过程的终极状态,具有如下特征:终极性.稳定性.吸引性.吸引子是一个数学概念,描写运动的收敛类型.它是指这样的一个集合,当时间趋于无穷大时,在任何一个有界集上出 ...
- Gulan查询UI排布
遇到一个问题,如何在相对布局里把两个item放在同一行,而且高度一样呢? <RelativeLayout xmlns:android="http://schemas.android.c ...
- 安装redis监控
在修改登录中心的时候,数据存储在redis里面,需要对redis进行监控,使用的是Redis-Live 参考文章: http://www.nkrode.com/article/real-time-da ...
- 删除windows系统中以前的设备(比如以前的网卡)或驱动的方法
1.在“开始”菜单单击“运行”,然后在“运行”对话框中输入“CMD”命令打开命令提示符窗口:2.在提示符窗口中输入“Set devmgr_show_nonpresent_devices=1”并回车:3 ...
- Folder Recursion with C#
by Richard Carr, published at http://www.blackwasp.co.uk/FolderRecursion.aspx Some applications must ...
- linux 下 取进程占用内存(MEM)最高的前10个进程
# linux 下 取进程占用 cpu 最高的前10个进程ps aux|head -1;ps aux|grep -v PID|sort -rn -k +3|head # linux 下 取进程占用内存 ...
- CSS3学习笔记--transform基于原始数据(旋转木马实例)
参考链接:好吧,CSS3 3D transform变换,不过如此! transform-style:preserve-3d属性要在图片所在的容器(父元素)中定义,perspective定义在父子元素上 ...
- Strategy策略设计模式
1.策略模式和状态模式的区别和联系(本部分转载自:http://letscoding.cn/java%E4%B8%AD%EF%BC%8C%E7%8A%B6%E6%80%81%E6%A8%A1%E5%B ...
- iOS开发——项目实战总结&数据持久化分析
数据持久化分析 plist文件(属性列表) preference(偏好设置) NSKeyedArchiver(归档) SQLite 3 CoreData 当存储大块数据时你会怎么做? 你有很多选择,比 ...
- Ajax学习笔记(二)
二.prototype库具体解释 1.prototype库的使用 //导入下载好的prototype.js文件 <script type="text/javascript" ...