Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

单表操作(增删改查)

补充知识点:

create_time = models.DateField()    #代表年月日

DateField中关键性的参数:

  1.auto_now:每次操作数据,都会自动刷新当前操作的时间

  2.auto_now_add:在创建数据的时候,会自动将创建的时间记录下来,后续的修改不影响该字段

方式1:create

book_obj =models.Book.objects.create(title='三国',price=19.99,create_time='2019-11-11')
print(book_obj.title)

方式2:对象点save()方法

from datetime import datetime
ctime = datetime.now()
book_obj = models.Book(title='水浒传',price=96.66,create_time=ctime)
book_obj.save()

查 (get,filter,all)

print(models.Book.objects.all())    #返回Queryset对象
print(models.Book.objects.get(id=1)) #返回具体的对象,当查询结果有多个值的时候会报错
print(models.Book.objects.get(pk=1))
"""
pk会自动查找到当前数据的主键字段
"""
print(models.Book.objects.filter(pk=2)) #返回Queryset对象

方式1:update

models.Book.objects.filter(pk=1).update(title='三国演义')

方式2:对象.save()

book_obj = models.Book.objects.get(pk=1)
book_obj.price = 666.66
book_obj.save()

删除

delete()

models.Book.objects.filter(pk=2).delete()

单表查询之必知必会13条

操作下面的操作之前,我们实现创建好了数据表,这里主要演示下面的操作,不再细讲创建准备过程

<1> all(): 查询所有结果

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

<2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

<3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

<4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象
Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

<5> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列,得到的结果是列表套字典
Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

<6> values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列,得到的结果是列表套元组
Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

<7> order_by(*field): 对查询结果排序
<8> reverse(): 对查询结果反向排序,请注意reverse()通常只能在具有已定义顺序的QuerySet上调用(在model类的Meta中指定ordering或调用order_by()方法)。
<9> distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。此时可以使用distinct(),注意只有在PostgreSQL中支持按字段去重。)

必须所有的字段都完全重复,才能去重

<10> count(): 返回数据库中匹配查询(QuerySet)的对象数量。
Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

<11> first(): 返回第一条记录
Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

<12> last(): 返回最后一条记录
<13> exists(): 如果QuerySet包含数据,就返回True,否则返回False

单表查询之神奇的双下划线

查询价格大于200的书籍

models.Book.objects.filter(price__gt=200)  #price>200   大于__gt

查询价格小于200的书籍

models.Book.objects.filter(price__lt=200)  小于__lt

查询价格大于等于200的书籍

models.Book.objects.filter(price__gte=200)  大于等于__gte

查询价格小于等于200的书籍

models.Book.objects.filter(price__lte=200)  小于等于__lte

查询价格要么是200,要么是300,要么是600

models.Book.objects.filter(price__in=[200,300,600])  在什么之间选择一个__in

查询价格在200到800之间

models.Book.objects.filter(price__range=(200,800))   在什么范围之间__range

查询书籍名字中包含p的

models.Book.objects.filter(title__contains='p')  # 仅仅只能拿小写p     包含__contains
models.Book.objects.filter(title__icontains='p') # 忽略大小写

查询书籍是以三开头,以p结尾

models.Book.objects.filter(title__startswith='三')  开头
models.Book.objects.filter(title__endswith='p') 结尾

查询出版日期是2017年的

models.Book.objects.filter(create_time__year='')

Django ORM常用字段和字段参数和关系字段

1.ORM常用字段

AutoField

int自增列,必须填入参数 primary_key=True。当model中如果没有写自增列,则自动会创建一个列名为id的列。(可以不写,会自动创建主键为id的字段)

IntegerField

一个整数类型,范围在 -2147483648 to 2147483647。(一般不用它来存手机号(位数也不够),直接用字符串存,)

CharField

字符类型,必须提供max_length参数, max_length表示字符长度。

DateField

日期字段,日期格式  YYYY-MM-DD,相当于Python中的datetime.date()实例。

配置auto_now_add=True,创建数据记录的时候会把当前时间添加到数据库。修改数据记录不会更新该字段
配置上auto_now=True,每次更新数据记录的时候会更新该字段。

DateTimeField

日期时间字段,格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ],相当于Python中的datetime.datetime()实例

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

2.ORM字段参数

null   用于表示某个字段可以为空。 null = True  设置字段允许为空

unique  如果设置为unique=True 则该字段在此表中必须是唯一的 。

db_index  如果db_index=True 则代表着为此字段设置索引。

default  为该字段设置默认值。

3.关系字段

(1)Foreignkey  一对多

比如书籍和出版社的关系

外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。

ForeignKey可以和其他表做关联关系同时也可以和自身做关联关系。

字段参数

to   设置要关联的表

to_field   设置要关联的表的字段

on_delete 当删除关联表中的数据时,当前表与其关联的行的行为。

models.CASCADE  删除关联数据,与之关联也删除,级联删除

db_constraint   是否在数据库中创建外键约束,默认为True。

models.DO_NOTHING
删除关联数据,引发错误IntegrityError models.PROTECT
删除关联数据,引发错误ProtectedError models.SET_NULL
删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空) models.SET_DEFAULT
删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值) models.SET 删除关联数据,
a. 与之关联的值设置为指定值,设置:models.SET(值)
b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)

其余字段参数

class MyModel(models.Model):
user = models.ForeignKey(
to="User", #关联User表
to_field="id", #关联User表id字段
on_delete=models.SET(func)
)

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

(2)OneToOneField   一对一

比如作者表和作者详情表

通常一对一字段用来扩展已有字段。(通俗的说就是一个人的所有信息不是放在一张表里面的,简单的信息一张表,隐私的信息另一张表,之间通过一对一外键关联),随便建在哪张表上都可以,但是建议建在查询频率高的那一组。

to   设置要关联的表。

to_field    设置要关联的字段。

on_delete    当删除关联表中的数据时,当前表与其关联的行的行为。(参考上面的例子)

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

(3)ManyToManyField   多对多

比如书籍表和作者表

多对多生成一张新的表,下面设置的字段不会在book表中出现,它仅仅是一个虚拟字段

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

新生成的表

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

Django终端打印SQL语句

如果你想知道你对数据库进行操作时,Django内部到底是怎么执行它的sql语句时可以加下面的配置来查看

在Django项目的settings.py文件中,在空白处复制粘贴如下代码:

LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console':{
'level':'DEBUG',
'class':'logging.StreamHandler',
},
},
'loggers': {
'django.db.backends': {
'handlers': ['console'],
'propagate': True,
'level':'DEBUG',
},
}
}

配置好之后,再执行任何对数据库进行操作的语句时,会自动将Django执行的sql语句打印到pycharm终端上

补充:

除了配置外,还可以通过一点.query即可查看查询语句,具体操作如下:

Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

上一篇:EF6配合MySQL或MSSQL(CodeFirst模式)配置指引


下一篇:spring错误:Could not resolve placeholder XXX in string value XXX