zoukankan      html  css  js  c++  java
  • 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(): 查询所有结果

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

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

    <4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象

    <5> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列,得到的结果是列表套字典

    <6> values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列,得到的结果是列表套元组

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

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

    <10> count(): 返回数据库中匹配查询(QuerySet)的对象数量。

    <11> first(): 返回第一条记录

    <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='2017')

    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()实例

    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)
        )

    (2)OneToOneField   一对一

    比如作者表和作者详情表

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

    to   设置要关联的表。

    to_field    设置要关联的字段。

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

    (3)ManyToManyField   多对多

    比如书籍表和作者表

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

     新生成的表

     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即可查看查询语句,具体操作如下:

  • 相关阅读:
    zookeeper编译环境搭建
    windows下zookeeper安装并发布成windows服务
    ScheduledThreadPoolExecutor源码
    AbstractExecutorService源码
    FutureTask源码2
    FutureTask源码
    ThreadPoolExecutor源码2
    ThreadPoolExecutor源码1
    二进制转10进制
    Android ANR Waiting because no window has focus问题分析
  • 原文地址:https://www.cnblogs.com/wangcuican/p/11553094.html
Copyright © 2011-2022 走看看