zoukankan      html  css  js  c++  java
  • django之model多表操作

    一对多表之间的查询:

    class userInfo(models.Model):
        name = models.CharField(max_length=50)
        password = models.CharField(max_length=50)
        email = models.EmailField()
        user_type = models.ForeignKey('userType')
    class userType(models.Model):
        name = models.CharField(max_length=50)

    1.all,get,filter

    ·all:所有数据(序列)

    ·get:单挑数据,是一个对象(封装一行多列数据)

    ·filter:序列

      eg: 取id>5

        userInfo.objects.filter(id__gt = 5)

      eg:userType大于5的所有用户信息

        userInfo.objects.filter(user_type__id__gt=5 )

        说明:user_type就是userType对象

      eg:userType大名字包含a的所有用户信息

        userInfo.objects.filter(user_type__name__contains='a' )

        说明:user_type就是userType对象

      eg:查看用户类型等于超级管理员的所有用户

        userInfo.objects.filter(user_type__name = "超级管理员")==select * from userInfo xxx

        userInfo.objects.filter(user_type__name = "超级管理员").values('username') == select username from xxx

    总结:对象__列名__方法 = ' '

    多对多表之间查询:

    class userInfo(models.Model):
        name = models.CharField(max_length=50)
        password = models.CharField(max_length=50)
        email = models.EmailField()
        user_type = models.ForeignKey('userType')
    
    class userGroup(models.Model):
        group = models.CharField(max_length=50)
        user = models.ManyToManyField('userInfo')

    1.建立关系

       t3 = userType.objects.get(name='supper')
        t4 = userType.objects.get(name='nomal')
        u1 = userInfo.objects.create(name='yj1',password='123',email='1@qq.com',user_type=t3) 
        u2 = userInfo.objects.create(name='yj1',password='123',email='1@qq.com',user_type=t4)
        groupObjA = userGroup.objects.create(group='HOSTA')
        groupObjA.user.add(u1) 
        groupObjB = userGroup.objects.create(group='HOSTB')
        groupObjB.user.add(u2)

    分析: 两表多对多实质上就是用一个新表记录其关系, groupObjA.user.add(u1)可以理解为先执行groupObjA.user,即在表中插入groupObjA的id;再执行.add(u1),即插入u1的id

     2.两种建立方式

      1)groupObjA.user.add(u1)     == groupObjA有多对多字段

      2)   u1.userGroup_set.add(groupObjA) == u1无多对多字段

       

        

  • 相关阅读:
    ThinkPHP 中 where条件 or,and 同时使用
    mysql客户端 navicat 本地导入sql文件出错
    mysql查询出所有重复的记录
    JS返回上一页并刷新
    Jquery计算指定日期加上多少天、加多少月、加多少年的日期
    JS获取当前完整的url地址以及参数的方法
    PHP 计算两个时间戳之间相差的时间
    mysql左连接右连接(查询两张表不同的数据)
    C++中的C
    C++编程思想
  • 原文地址:https://www.cnblogs.com/yejiang/p/10322327.html
Copyright © 2011-2022 走看看