Django学习系列之ORM-QuerySetAPI
基本操作
# 增 models.Tb1.objects.create(c1='xx', c2='oo') #增加一条数据,可以接受字典类型数据 **kwargs obj = models.Tb1(c1='xx', c2='oo')
obj.save() dic = {'c1':'xx','c2':'oo'}
models.Tb1.objects.create(**dic) #Form的产出结果是一个字典,可以根据这个Form的字典和**直接在数据库创建数据 # 查
models.Tb1.objects.get(id=123) # 获取单条数据,不存在则报错(不建议)
models.Tb1.objects.all() # 获取全部 .first() 取第一条数据
models.Tb1.objects.filter(name='seven') # 获取指定条件的数据 也可以用**的方式传参数
models.Tb1.objects.filtet(name__icontains='Searcher') #过滤name字段包含Searcher的值并且不区分大小写,i是不区分大小写,contains是包含
models.Tb1.objects.filter(name='server').exclude(age='16') #获取指定条件的数据,但是排除某个条件(获取所有name=server的内容,但是排除age=16的) # 删 models.Tb1.objects.filter(name='seven').delete() # 删除指定条件的数据 # 改 models.Tb1.objects.filter(name='seven').update(gender='') # 将指定条件的数据更新,均支持 **kwargs obj = models.Tb1.objects.get(id=1)
obj.c1 = ''
obj.save() # 修改单条数据 #排除
models.Tb1.objects.order_by('name') #升序
models.Tb1.objects.order_by('-name') #降序
细看从数据库取出的类型
w = models.Simp.objects.all()
print w, type(w)
[<Simp: chenc>, <Simp: zan>, <Simp: zhangsan>] <class 'django.db.models.query.QuerySet'>
#可以看到,从数据库取出个数据看起来像包含对象的列表。而实际上整个数据为django中的特殊类型 QuerySet 。
.all() 是取得所有列的数据,可以加 .values() 取出某一列,每一项的值为一个 字典 :
w = models.Simp.objects.all().values('username')
print w, type(w) [{'username': u'chenc'}, {'username': u'zan'}, {'username': u'zhangsan'}] <class 'django.db.models.query.QuerySet'>
.values_list(),获取到的值为一个 元组
w = models.Simp.objects.all().values_list('username')
print w, type(w) [(u'chenc',), (u'zan',), (u'zhangsan',)] <class 'django.db.models.query.QuerySet'>
.values_list() 也可以添加多个参数:( 可以配合Form在前端生成动态的select )
w = models.Simp.objects.all().values_list('id', 'username')
print w, type(w) [(1, u'chenc'), (2, u'zan'), (3, u'zhangsan')] <class 'django.db.models.query.QuerySet'>
query 可以查看执行的sql语句:
b = models.Simp.objects.all()
print b.query SELECT "app01_simp"."id", "app01_simp"."username", "app01_simp"."password" FROM "app01_simp"
利用双下划线将字段和对应的操作连接起来
1 # 获取个数
2 #
3 # models.Tb1.objects.filter(name='seven').count()
4
5 # 大于,小于
6 #
7 # models.Tb1.objects.filter(id__gt=1) # 获取id大于1的值
8 # models.Tb1.objects.filter(id__lt=10) # 获取id小于10的值
9 # models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值
10
11 # in
12 #
13 # models.Tb1.objects.filter(id__in=[11, 22, 33]) # 获取id等于11、22、33的数据
14 # models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in
15
16 # contains
17 #
18 # models.Tb1.objects.filter(name__contains="ven")
19 # models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
20 # models.Tb1.objects.exclude(name__icontains="ven")
21
22 # range
23 #
24 # models.Tb1.objects.filter(id__range=[1, 2]) # 范围bettwen and
25
26 # 其他类似
27 #
28 # startswith,istartswith, endswith, iendswith,
29
30 # order by
31 #
32 # models.Tb1.objects.filter(name='seven').order_by('id') # asc 从小到大
33 # models.Tb1.objects.filter(name='seven').order_by('-id') # desc 从大到小
34
35 # limit 、offset
36 #
37 # models.Tb1.objects.all()[10:20]
38
39 # group by
40 from django.db.models import Count, Min, Max, Sum
41 # models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num'))
42 # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"
多对多关系操作
一、准备
1.创建多对多关系表
model.py
class Aihao(models.Model):
''爱好表'''
name = models.CharField(max_length=122)
person = models.ManyToManyField('Person') def __str__(self):
return self.name class Person(models.Model):
''人表'''
name= models.CharField(max_length=122) def __str__(self):
return self.name 一个人有多个爱好,一个爱好可以被多个人拥有
2.生成数据库
python3.5 manage.py makemigrations
python3.5 manage.py migrate
3.在数据库客户端的展示
-爱好表里有一条数据,id是1
-人表里有一条数据,id是1
-这张表是自动创建的,存储人和爱好的对应关系,这个表就是把人和爱好关联起来,可以看到aihao_id就是代表的爱好ID,person_id就是代表的人,就是person为Alex,爱好为吃饭
4.操作
查询
从人出发获取爱好
from app01.models import * >>> p = Person.objects.get(id=2) #获取一个人 的对象 >>> p.aihao.all() #获取这个人的所有爱好
<QuerySet [<Aihao: 吃饭>, <Aihao: 玩电脑>]>
从爱好出发获取人
>>> a = Aihao.objects.get(id=3) #获取一个爱好 的对象 >>> a.person_set.all() #获取有这个爱好的所有人
<QuerySet [<Person: Alex>]>
删除
from app01.models import * #删除和一个人相关的所有爱好
>>> d = Person.objects.get(id=3) #获取Person表中id=3的人
>>> d.aihao.all() #获取第三张表中(关系对应表) id=3这个人的爱好
<QuerySet [<Aihao: 吃饭>, <Aihao: 玩电脑>]>
>>>d.aihao.clear() #在第三张表(关系对应表)中删除和id=3这个人关联的数据
>>> d.aihao.all() #获取第三张表中 id=3这个人的爱好
<QuerySet [<>]> #现在已经没了 #删除和这个爱好相关的所有人
>>> d = Person.objects.get(id=2) #获取一个人 的对象
>>> d.aihao.clear() #删除和这个人关联的所有爱好
注意:
如果多个表(爱好表[relate_name=aihao_person_set],manytomany到person表,兴趣表[relate_name=xingqu_person_set],manytomany到person表,)
都manytomany到Person表
那每个表manytomany的字段都得设置relate_name字段
如果想通过爱好表反查或者兴趣表反查
比如获取有这个爱好的所有人[a = aihao.object.get(id=2),a.aihao_person_set.all()]
获取有这个兴趣的所有人 [a = xingqu.object.get(id=2),a.xingqu_person_set.all()]
一对多关系操作
表结构
class User(models.Model):
'''用户表'''
name = models.CharField(max_length=20) def __str__(self):
return self.name class UserType(models.Model):
'''用户类型表'''
name = models.CharField(max_length=20)
user = models.ForeignKey(User)
在数据库客户端查看
User表:
UserType表:
注:user_id字段就是User表的外键
表结构(models.py)
class Asset(models.Model):
hostname = models.CharField(max_length=64, unique=True)
os_type = models.CharField('操作系统类型',max_length=64, blank=True,null=True)
os_distribution = models.CharField('发型版本',max_length=64, blank=True,null=True)
os_release = models.CharField('操作系统版本',max_length=64, blank=True,null=True)
inside_ip = models.GenericIPAddressField('内网IP', blank=True, null=True)
outside_ip = models.GenericIPAddressField('外网IP', blank=True, null=True) sn = models.CharField('资产SN号',max_length=128, unique=True)
business_unit = models.ForeignKey('BusinessUnit', verbose_name='所属业务线',null=True, blank=True)
admin = models.ForeignKey(UserProfile, verbose_name=u'资产管理员',null=True, blank=True)
memo = models.TextField('备注', null=True, blank=True) model = models.CharField('型号',max_length=128,null=True, blank=True )
kernelrelease = models.CharField('内核',max_length=128,null=True, blank=True )
create_date = models.DateTimeField(blank=True, auto_now_add=True)
update_date = models.DateTimeField(blank=True,null=True)
class Meta:
verbose_name = '资产'
verbose_name_plural = "资产"
def __str__(self):
return '%s sn:%s' %(self.hostname,self.sn) class RAM(models.Model):
'''
内存条
'''
asset = models.ForeignKey('Asset') #这里asset是Asset表的外键,在RAM表中这个字段实际为asset_id,就是Asset表中的id字段(因为Asset表中的id字段是唯一的,所以代表这个RAM属于这个Asset),可以根据asset_id获取Asset表中的信息
capacity = models.IntegerField('内存大小(MB)')
create_date = models.DateTimeField(blank=True, auto_now_add=True)
update_date = models.DateTimeField(blank=True,null=True)
memo = models.CharField('备注',max_length=128, blank=True,null=True)
# auto_create_fields = ['sn','slot','model','capacity']
def __str__(self):
return '%s:%s' % (self.asset_id,self.capacity)
class Meta:
verbose_name = '内存'
verbose_name_plural = "内存"
因为是一对多关系,所以一个Asset表对应多个RAM表(一个资产可以有多个内存条),RAM表中asset(asset_id)是Asset表的id,也就是Asset表的外键
示例一:获取某个资产下的所有内存条(根据"一"获取"多")
代码:
>>> a = Asset.objects.get(id=1) #获取id=1的资产信息
>>> b = a.ram_set.select_related()) #等同于 a.ram_set_all()
...
结果:
<QuerySet [<RAM: 4:1234>, <RAM: 4:2312>]>
示例二:获取某个资产下的每个内存条的capacity值(根据"一"获取一个"多"的某个值)
代码:
>>> a = Asset.objects.get(id=1) #获取id=1的资产信息
>>> b = a.ram_set_all() #获取id=1资产下的所有内存条信息
>>> for i in b: #循环所有内存条,取出每个内存条的capacity
... print(i.capacity)
... 结果:
1234
2312
示例三:获取某个内存条属于哪个资产(根据"多"获取"一")
代码
a = RAM.objects.get(id=) #获取这个内存条
b = a.asset.name #获取这个内存条属于哪个资产,获取name字段
结果:
172-16-1-213
示例四:在RAM表中获取属于Asset表id为10的所有内存条(根据外键获取信息)
all_ram = RAM.objects.filter(asset_id=)
#这就获取了所有数据asset_id为10的内存条
一对一关系操作
表结构(models.py)
class Asset(models.Model):
hostname = models.CharField(max_length=64, unique=True)
os_type = models.CharField('操作系统类型',max_length=64, blank=True,null=True)
os_distribution = models.CharField('发型版本',max_length=64, blank=True,null=True)
os_release = models.CharField('操作系统版本',max_length=64, blank=True,null=True)
inside_ip = models.GenericIPAddressField('内网IP', blank=True, null=True)
outside_ip = models.GenericIPAddressField('外网IP', blank=True, null=True) sn = models.CharField('资产SN号',max_length=128, unique=True)
business_unit = models.ForeignKey('BusinessUnit', verbose_name='所属业务线',null=True, blank=True)
admin = models.ForeignKey(UserProfile, verbose_name=u'资产管理员',null=True, blank=True)
memo = models.TextField('备注', null=True, blank=True) model = models.CharField('型号',max_length=128,null=True, blank=True )
kernelrelease = models.CharField('内核',max_length=128,null=True, blank=True )
create_date = models.DateTimeField(blank=True, auto_now_add=True)
update_date = models.DateTimeField(blank=True,null=True)
class Meta:
verbose_name = '资产'
verbose_name_plural = "资产"
def __str__(self):
return '%s sn:%s' %(self.hostname,self.sn) class CPU(models.Model):
'''
CPU的基本类型
'''
asset = models.OneToOneField('Asset')
cpu_model = models.CharField('CPU型号', max_length=128,blank=True)
cpu_count = models.SmallIntegerField('物理cpu个数')
cpu_core_count = models.SmallIntegerField('cpu核数')
create_date = models.DateTimeField(verbose_name='创建时间',auto_now_add=True)
update_date = models.DateTimeField(verbose_name='更新时间',blank=True,null=True)
memo = models.TextField('备注', null=True,blank=True)
class Meta:
verbose_name = 'CPU'
verbose_name_plural = "CPU"
def __str__(self):
return self.cpu_model
因为是一对一关系,所以一个Asset表只能对应一个CPU表
示例一:获取关联Asset表的CPU表的cpu_model值和cpu_cont值和cpu_core_count值
代码:
>>> a = models.Asset.objects.all()
>>> for i in a:
... print(i.cpu.cpu_model,i.cpu.cpu_count,i.cpu.cpu_core_count)
... 结果
hype -v 2 2
数据库如果添加字段之后执行makemigrations 表名然后执行migrate 表名
Django学习系列之ORM-QuerySetAPI的更多相关文章
- Django学习系列之Form基础
Django学习系列之Form基础 2015-05-15 07:14:57 标签:form django 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追 ...
- Django学习系列6:使用selenium测试用户交互
学习系列5中的单元测试有报错信息,这儿来编写functional_tests.py文件,扩充其中的功能测试 # File: functional_test.py # Author: Rxf # Cre ...
- Django学习系列13:Django ORM和第一个模型
ORM—对象关系映射器,是一个数据抽象层,描述存储在数据库中的表,行和列.处理数据库时,可以使用熟悉的面向对象方式,写出更好的代码. 在ORM的概念中,类对应数据库中的表,属性对应列,类的单个实例表示 ...
- django学习系列——python和php对比
python 和 php 我都是使用过,这里不想做一个非常理性的分析,只是根据自己的经验谈一下感想. 在web开发方面,无疑 php 更甚一筹. 从某种角度来说,php 就是专门为 web 定制的语言 ...
- MVC3+EF4.1学习系列(四)----- ORM关系的处理
上篇文章 终于把基础的一些操作写完了 但是这些都是单表的处理 而EF做为一个ORM框架 就必须点说说对于关系的处理 处理好关系 才能灵活的运用EF 关于关系的处理 一般就是 一对一 一对多 ...
- Django学习笔记之ORM多表操作
创建模型 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是一对一的关 ...
- Django学习笔记之ORM字段和字段参数
Object Relational Mapping(ORM) 一.ORM介绍 1. ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象 ...
- Django学习之 - 基础ORM
ORM操作参考: http://www.cnblogs.com/wupeiqi/articles/5246483.html 1:根据类自动创建数据库表,(类创建文件:models.py) 2:根据类对 ...
- Django学习系列之Python+Xadmin
项目树 引入xadmin pycharm在项目中创建存放xadmin的目录 右键项目名称-->pythonpackage-->输入名称:extra_app 拷贝xadmin代码到extra ...
- Django学习系列14:第一个数据库迁移
在Django中,ORM的任务是模型化数据库. 创建数据库其实是由另一个系统负责的叫做迁移. 迁移的任务是根据你对models.py文件的改动情况,添加或删除表和列. 可以把迁移想象成数据库使用的版本 ...
随机推荐
- Sql Server中清空所有数据表中的记录
Sql Server中清空所有数据表中的记录 清空所有数据表中的记录: 代码如下:exec sp_msforeachtable @Command1 ='truncate table ?'删除所有数据 ...
- SQL——时间戳
mysql 低版本,date.datetime.timestamp 无法精确到毫秒 可以舍弃时间类型字段,用 bigint 来代替,如果用字符串类型代替,还是比较担心排序的时候只是根据第一个字母进行排 ...
- TP-LINK路由器桥接功能实现(WDS)
弄过好几次路由器的桥接了,但每次都忘记了,要重新找资料.在此记录一下,方便以后使用. 准备工作: 1.设置本地连接/无线网络连接(取决于用哪个配置路由器):IP-192.168.1.100 掩码-25 ...
- AWT编程时,Button按钮上的中文编程□□□
今天学到AWT编程时,照着书上的代码打,代码如下: import java.awt.*; public class PanelTest{ public static void main(Stri ...
- 机器学习_决策树Python代码详解
决策树优点:计算复杂度不高,输出结果易于理解,对中间值的缺失不敏感,可以处理不相关特征数据: 决策树缺点:可能会产生过度匹配问题. 决策树的一般步骤: (1)代码中def 1,计算给定数据集的香农熵: ...
- mysql.connector.errors.IntegrityError: 1048 (23000): Column 'request_url' cannot be null
箭头指向的2的方向 少了一个request_url的值 调试: 直接 执行sql语句 是没问题的, 这样就知道问题是出在代码的逻辑 处理了: INSERT INTO response_time (nu ...
- ActiveX控件获取不到对象属性或者方法的原因分析
1.找不到调用的DLL或程序: 2.调用控件方法名称,与定义的函数名称不符合: 3.如果是网站网页调用ActiveX,检查控件是否添加安全对象: 4.如果是网站网页调用ActiveX,检查网页是否加入 ...
- java.util.MissingResourceException: Can't find bundle for base name db, locale zh_CN
在使用Bundle来加载配置文件的时候, 爆出了这个错误: 原因? 没有找到需要加载的配置文件,因为配置文件必须放在src目录下面, 如果放进了com.bj186.crm的包下面,就必须添加包的名称到 ...
- 05CSS链接
CSS链接 链接的四种状态: • a:link - 普通的.未被访问的链接 • a:visited - 用户已访问的链接 • a:hover - 鼠标指针位于链接的上方 • a:active ...
- 布尔上下文,这里misreading返回的是来源列表中元素的个数,如果列表中2个值都是undef,则列表元素个数是1: while( $misreading = (my $test_consideration, my $english_pragma) = each %map_function){
布尔上下文,这里misreading返回的是来源列表中元素的个数, 列表赋值运算的值将会是来源列表中元素的个数,空列表表示0,如果列表中2个值都是undef,则列表元素个数是1 布尔上下文,这里mis ...