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 ...
随机推荐
- Python多线程编程之多线程加锁
Python语言本身是支持多线程的,不像PHP语言. 下面的例子是多个线程做同一批任务,任务总是有task_num个,每次线程做一个任务(print),做完后继续取任务,直到所有任务完成为止. #co ...
- [Aaronyang] 写给自己的WPF4.5 笔记22 [3d交互与动画 3/4]
OK,前面我们的3d模型都比较囧啊,最近也看了一点ZAM了解了一下,大致至少可以做个简单的模型用来演示. 1.交互,动起来的思路 ①修改Model3D对象的变换 ②修改应用于ModelVisual3D ...
- Ext4,Ext3的特点和区别(转)
Linux kernel 自 2.6.28 开始正式支持新的文件系统 Ext4. Ext4 是 Ext3 的改进版,修改了 Ext3 中部分重要的数据结构,而不仅仅像 Ext3 对 Ext2 那样,只 ...
- Windows XP 中设置VPN(PPTP连接方式)
第一步:点开始-网上邻居或者控制面板-网络连接,选择-创建一个新的连接 第二步:点击-下一步 第三步:选择-连接到我的工作场所的网络,点击-下一步 第四步:选择-虚拟专用网络连接,点击-下一步 第五步 ...
- android 透明度颜色值
100% — FF99% — FC98% — FA97% — F796% — F595% — F294% — F093% — ED92% — EB91% — E890% — E689% — E388% ...
- TargetProcess 中更改了域名如何修改里面的附件地址
在默认情况,TP 安装的目录是默认的网站(IIS)的targetprocess2下面,但是如果想采用 tp.targetprocess.cn 这种方式直接访问,则需要做一些设置. 基本要点如下: 1. ...
- BW CUBE 数据的聚集和压缩
大家都知道,压缩和聚集都是提高bw性能的方法,在新版bw里,压缩名称改成了折叠,聚集放在了滚动菜单里---集合.那么我们在使用这两种方法时需要注意的先创建聚集以后,再进行压缩,因为压缩的过程是把F表的 ...
- VC 2010的重大变化
auto 关键字具有新的默认含义.由于使用旧含义的情况很少见,因此大多数应用程序都不会受此更改影响. 引入了新的 static_assert 关键字,如果代码中已经存在具有某个名称的标识符,则此关键字 ...
- CISA 信息系统审计知识点 [第一章. 信息系统审计过程 ]
对有志成为审计师或者IT管理者de朋友, 第一章. 信息系统审计过程 1. IS 审计和保障标准.指南.工具.职业道德规范 信息技术保证框架(ITAF,Information Technology A ...
- 物料分类账 [COML] PART 1 - 概览
物料分类账 [COML] PART 1 - 概览 一).原理 1). •实际成本/物料分类帐是产品成本控制模块的一个子模块,产品成本控制包括三个子模块,产品成本计划,成本对象控制,实际成本/物料分类帐 ...
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 ...
随机推荐
- Python多线程编程之多线程加锁
Python语言本身是支持多线程的,不像PHP语言. 下面的例子是多个线程做同一批任务,任务总是有task_num个,每次线程做一个任务(print),做完后继续取任务,直到所有任务完成为止. #co ...
- [Aaronyang] 写给自己的WPF4.5 笔记22 [3d交互与动画 3/4]
OK,前面我们的3d模型都比较囧啊,最近也看了一点ZAM了解了一下,大致至少可以做个简单的模型用来演示. 1.交互,动起来的思路 ①修改Model3D对象的变换 ②修改应用于ModelVisual3D ...
- Ext4,Ext3的特点和区别(转)
Linux kernel 自 2.6.28 开始正式支持新的文件系统 Ext4. Ext4 是 Ext3 的改进版,修改了 Ext3 中部分重要的数据结构,而不仅仅像 Ext3 对 Ext2 那样,只 ...
- Windows XP 中设置VPN(PPTP连接方式)
第一步:点开始-网上邻居或者控制面板-网络连接,选择-创建一个新的连接 第二步:点击-下一步 第三步:选择-连接到我的工作场所的网络,点击-下一步 第四步:选择-虚拟专用网络连接,点击-下一步 第五步 ...
- android 透明度颜色值
100% — FF99% — FC98% — FA97% — F796% — F595% — F294% — F093% — ED92% — EB91% — E890% — E689% — E388% ...
- TargetProcess 中更改了域名如何修改里面的附件地址
在默认情况,TP 安装的目录是默认的网站(IIS)的targetprocess2下面,但是如果想采用 tp.targetprocess.cn 这种方式直接访问,则需要做一些设置. 基本要点如下: 1. ...
- BW CUBE 数据的聚集和压缩
大家都知道,压缩和聚集都是提高bw性能的方法,在新版bw里,压缩名称改成了折叠,聚集放在了滚动菜单里---集合.那么我们在使用这两种方法时需要注意的先创建聚集以后,再进行压缩,因为压缩的过程是把F表的 ...
- VC 2010的重大变化
auto 关键字具有新的默认含义.由于使用旧含义的情况很少见,因此大多数应用程序都不会受此更改影响. 引入了新的 static_assert 关键字,如果代码中已经存在具有某个名称的标识符,则此关键字 ...
- CISA 信息系统审计知识点 [第一章. 信息系统审计过程 ]
对有志成为审计师或者IT管理者de朋友, 第一章. 信息系统审计过程 1. IS 审计和保障标准.指南.工具.职业道德规范 信息技术保证框架(ITAF,Information Technology A ...
- 物料分类账 [COML] PART 1 - 概览
物料分类账 [COML] PART 1 - 概览 一).原理 1). •实际成本/物料分类帐是产品成本控制模块的一个子模块,产品成本控制包括三个子模块,产品成本计划,成本对象控制,实际成本/物料分类帐 ...