zoukankan      html  css  js  c++  java
  • Django——7 常用的查询 常用的模型字段类型 Field的常用参数 表关系的实现

    Django

    1. 常用的查询
      1. 常用的查询方法
      2. 常用的查询条件
    2. 常用字段映射关系
    3. Field常用参数
    4. 表关系的实现

    查用的查询方法

    这是需要用到的数据

    from django.http import HttpResponse
    from .models import User
    
    def special_search(request):
    
    
        # 查询所有的记录
        res = User.objects.all()
        print(res)
    
    
        return HttpResponse('查询成功')

     

    # 查询第一条数据
        res = User.objects.first()

     

    # 查询最后一条数据
        res = User.objects.last()

     

    # 根据条件查询满足条件的结果
        res = User.objects.filter(name='李四')

     

    # 按条件获取排除以后的数据
        res = User.objects.exclude(name='周六')

     

    # 获取一个对象
        res = User.objects.get(name='王五')

     

    # 对结果进行排序
        res = User.objects.order_by('age')

     

    # 多项排序
        res = User.objects.order_by('age', 'id')

     

    # 逆向排序
        res = User.objects.order_by('-age')

     

    # 将返回的QuerySet数据转换成字典
        res = User.objects.all().values()

     

    这里可以发现,多出了city属性,因为

     

    我没有加上__str__的city属性的输出,可以得出结论:

    .values()方法可以直接获取模型数据的属性,不需要重定义输出

    # 查询数据的总数
        res = User.objects.count()

    常用的常洵条件

     

    查找对象的条件的意思是传给以上方法的一些参数。相当于是SQL语句中的where语句后面的条件,语法为字段名__规则(是连着连个下划线哦)

    # 等于exact  iexact忽略大小写
        res = User.objects.filter(name__exact='李四')

    # 包含contains icontains 忽略大小写
        res = User.objects.filter(name__contains='')

     

    # 以什么开始 startswith  istartswith忽略大小写
        res = User.objects.filter(name__startswith='')

     

    # 以什么结尾 endswith iendswith忽略大小写
        res = User.objects.filter(name__endswith='')

    # 成员所属 in
        res = User.objects.filter(age__in=[22, 23, 24])

    # gt 大于
        res = User.objects.filter(age__gt=22)

    # lt 小于
        res = User.objects.filter(age__lt=21)

    # 大于等于或者小于等于后面加上e
        res = User.objects.filter(age__gte=22)

    # 区间 range 
        res = User.objects.filter(age__range=(21, 22))

    # isnull 获取数据为空的
        res = User.objects.filter(city__isnull=True)
        # 获取不为空的数据
        print(User.objects.filter(city__isnull=False))

     

     常用字段映射关系

     

    • IntegerField : 整型,映射到数据库中的int类型。
    • CharField:  字符类型,映射到数据库中的varchar类型,通过max_length指定最大长度。
    • TextField:  文本类型,映射到数据库中的text类型。
    • BooleanField: 布尔类型,映射到数据库中的tinyint类型,在使用的时候,传递True/False进去。如果要可以为空,则用NullBooleanField。
    • DateField:  日期类型,没有时间。映射到数据库中是date类型,在使用的时候,可以设置DateField.auto_now每次保存对象时,自动设置该字段为当前时间。设置DateField.auto_now_add当对象第一次被创建时自动设置当前时间。
    • DateTimeField:   日期时间类型。映射到数据库中的是datetime类型, 在使用的时候,传递datetime.datetime()进去。

     Field的常用参数

    • primary_key:  指定是否为主键。
    • unique:  指定是否唯一。
    • null:  指定是否为空,默认为False。
    • blank: 等于True时form表单验证时可以为空,默认为False。
    • default:  设置默认值。
    • DateField.auto_now:  每次修改都会将当前时间更新进去,只有调用,QuerySet.update方法将不会调用。这个参数只是Date和DateTime以及TimModel.save()方法才会调用e类才有的。
    • DateField.auto_now_add:  第一次添加进去,都会将当前时间设置进去。以后修改,不会修改这个值

    models.py

    class Test(models.Model):
        name = models.CharField(max_length=10)
        age = models.IntegerField()
        note = models.TextField()
        gender = models.BooleanField(default=True)
        create_time = models.DateField(auto_now_add=True)
        update_time = models.DateTimeField(auto_now=True)

     创建映射文件并生成数据表

     查看数据结构:

    我们来添加数据

    views:

    def test(request):
        Test.objects.get_or_create(name='A', age=18, note='I am A', gender=True)
        Test.objects.get_or_create(name='B', age=19, note='I am B', gender=False)
        return HttpResponse('数据添加成功')

    需要注意的一点:update_time,只用通过.save()方法,才能实现更新

     现在运行如下代码:

    def test(request):
        # Test.objects.get_or_create(name='A', age=18, note='I am A', gender=True)
        # Test.objects.get_or_create(name='B', age=19, note='I am B', gender=False)
        Test.objects.filter(name='A').update(age=20)
        res = Test.objects.get(name='B')
        res.age = 22
        res.save()
        return HttpResponse('数据添加成功')

     

    表数据关系

    表关系举例

    创建学院表:

    class Department(models.Model):
        d_id = models.AutoField(primary_key=True)
        d_name = models.CharField(max_length=10)
        def __str__(self):
            return 'Department<d_id=%s, d_name=%s>'%(
                self.d_id, self.d_name
            )

     创建学生表,与学院表成一对多,外键关联:

    class Student(models.Model):
        s_id = models.AutoField(primary_key=True)
        s_name = models.CharField(max_length=10)
        department = models.ForeignKey('Department', on_delete=models.CASCADE)
    def __str__(self):
            return 'Student<s_id=%s, s_name=%s>'%(
                self.s_id, self.s_name
            )

    学生详情表,与学生表一对一

    class Stu_Detail(models.Model):
        s_id = models.OneToOneField('Student', on_delete=models.CASCADE)
        age = models.IntegerField()
        gender = models.BooleanField(default=True)
        city = models.CharField(max_length=30)
        def __str__(self):
            return 'Stu_Detail<s_id=%s, age=%s, gender=%s, city=%s>'%(
                self.s_id, self.age, self.gender, self.city
            )

     课程表,与学生表成多对多,自动生成三方表

    class Course(models.Model):
        c_id = models.AutoField(primary_key=True)
        name = models.CharField(max_length=10)
        student = models.ManyToManyField('Student')
    def __str__(self):
            return 'Course<c_id=%s, name=%s>'%(
                self.c_id, self.name
            )

     注意:

    • 外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然会报错!
    • 一般使用CASCADE表示级联删除
    • 关于on_delete还有其他的一些属性:
      • on_delete=models.CASCADE==>主表属性删除,相关联的子表属性会一并删除  (推荐)
      • on_delete=models.SET_NULL, null=True ==>主表属性删除,相关联的字表属性会变成NULL
      • on_delete=models.PROTECT==>有关联的时候,不允许删除,否则会报错


    执行完makemigrations和migrate的命令后,在数据库我们能看到5张表,其中多对多关系的ManyToManyField
    方法自动生成了关系表.



  • 相关阅读:
    关于postman与shiro权限验证问题
    springboot对shiro进行mock单元测试
    深入理解spring注解之@ComponentScan注解
    springboot项目启动,但是访问报404错误
    通过jedis连接redis单机成功,使用redis客户端可以连接集群,但使用JedisCluster连接redis集群一直报Could not get a resource from the pool
    重装系统后ORACLE数据库恢复的方法
    ORA-03113: end-of-file on communication channel 解决方法
    ORA-03113:通信通道的文件结尾-完美解决方案
    由于Windows和Linux行尾标识引起脚本无法运行的解决
    在cmd命令行中弹出Windows对话框(使用mshta.exe命令)
  • 原文地址:https://www.cnblogs.com/pywjh/p/10191146.html
Copyright © 2011-2022 走看看