单表操作

增加数据

    auther_obj = {"auther_name":"崔皓然","auther_age":1}
models.auther.objects.create(
**auther_obj
)

  

    models.auther.objects.create(
auther_name="周雍博",
auther_age=4
)

  

    obj = models.auther(
auther_name="崔洪艳",
auther_age=29
)
obj.save()

  

    obj = models.auther(
auther_name = "王仙枝",
auther_age = "50"
)
obj.save()

  

删除数据

models.auther.objects.filter(auther_name="崔洪艳")[0].delete()

  

一对多操作

增加数据

    a_obj = models.auther.objects.get(id=1)

    models.book.objects.create(
book_name = "python课程1",
book_price = 12,
book_auther = a_obj
)

  

    a_obj = models.auther.objects.get(id=5)

    models.book.objects.create(
book_name = "java课程1",
book_price = 13,
book_auther_id = a_obj.id
)

  

    a_obj = models.auther.objects.get(id=2)

    book_dict = {
"book_name":"python课程2",
"book_price":14,
"book_auther_id":a_obj.id
} obj = models.book.objects.create(
**book_dict
)

  

    a_obj = models.auther.objects.get(id=4)

    book_dict = {
"book_name":"java课程2",
"book_price":15,
"book_auther":a_obj
} models.book.objects.create(
**book_dict
)

  

一对多正向查询

    # 查询id为2的书的所有作者的信息
obj = models.book.objects.get(id=2) print(obj.book_auther.auther_name)
print(obj.book_auther.auther_age) obj = models.book.objects.filter(id=2).values("book_name","book_price","book_auther__id","book_auther__auther_name","book_auther__auther_age") print(obj)

  

    # 查询id为2的作者的出版的书

    obj = models.book.objects.filter(book_auther_id=2).values("book_name","book_price","book_auther__id","book_auther__auther_name","book_auther__auther_age")
print(obj) obj = models.book.objects.get(book_auther_id=2)
print(obj.book_auther.auther_age)
print(obj.book_auther.auther_name)
print(obj.book_name)

  

一对多反向查询

    # 查看出版社出版的书

    obj = models.auther.objects.filter(id=2).values("auther_name","auther_age","book__book_name")
print(obj) obj = models.auther.objects.get(id=2).book_set.values("book_name","book_price","book_auther__id","book_auther__auther_name","book_auther__auther_age")
print(obj)

  

多对多操作

增加数据

    b1 = models.book.objects.get(id=1)
b2 = models.book.objects.get(id=2)
b4 = models.book.objects.get(id=4)
b5 = models.book.objects.get(id=5)
models.publish.objects.get(id=1).publish_book.add(
b1,b2
)

  

    book_list = [b1,b2]

    models.publish.objects.get(id=2).publish_book.add(
*book_list
)

  

更新数据

    book_list = [b1,b2,b4,b5]
models.publish.objects.get(id=1).publish_book.set(book_list)

  

移除数据

    models.publish.objects.get(id=1).publish_book.remove(b1)

    book_list = [b2, ]

    models.publish.objects.get(id=1).publish_book.remove(*book_list)  

正向查询

    obj = models.publish.objects.get(id=1).publish_book.values("book_name","publish__publish_name")
print(obj) obj = models.publish.objects.filter(id=1).values("publish_name","publish_book__book_name")
print(obj)

  

反向添加数据

    p1 = models.publish.objects.get(id=1)
p2 = models.publish.objects.get(id=2)
p3 = models.publish.objects.get(id=3)
b1.publish_set.add(p1,p2,p3)

  

反向删除数据

b1.publish_set.remove(p1)

  

反向更新数据,把remove替换为set就可以了

反向查询

    obj = models.book.objects.get(id=1).publish_set.values("publish_name","publish_book__book_name")

  

model中多表关系和参数

多对多

一对一

model操作

django的model操作整理的更多相关文章

  1. Django之Model操作

    Django之Model操作 本节内容 字段 字段参数 元信息 多表关系及参数 ORM操作 1. 字段 字段列表 AutoField(Field) - int自增列,必须填入参数 primary_ke ...

  2. Python之路【第二十二篇】:Django之Model操作

    Django之Model操作   一.字段 AutoField(Field) - int自增列,必须填入参数 primary_key=True BigAutoField(AutoField) - bi ...

  3. Django之model操作(续)

    Django中的源码续 ################################################## # PUBLIC METHODS THAT RETURN A QUERYS ...

  4. Django之Model操作进阶篇

    常用参数 null 数据库中字段是否可以为空 db_column 数据库中字段的列名 default 数据库中字段的默认值 primary_key 数据库中字段是否为主键 db_index 数据库中字 ...

  5. django环境安装操作整理!

    1. Django 下载地址:https://www.djangoproject.com/download/ 注意:目前 Django 1.6.x 以上版本已经完全兼容 Python 3.x. 2.安 ...

  6. 补齐-Django之Model操作

    http://www.cnblogs.com/wupeiqi/articles/6216618.html

  7. Djang之Model操作

    Django之Model操作 一.字段 1.字段列表: AutoField(Field) - int自增列,必须填入参数 primary_key=True BigAutoField(AutoField ...

  8. django (四) model模型

    models模型 1. models 定义属性 概述 django根据属性的类型确定以下信息 ·当前选择的数据库支持字段的类型 ·渲染管理表单时使用的默认html控件 ·在管理站点最低限度的验证 dj ...

  9. Python学习笔记整理总结【Django】:Model操作(一)

    Model操作(一) 一.Django ORM基本配置 ORM:关系对象映射(Object Relational Mapping,简称ORM)db Frist:到目前为止,当我们的程序涉及到数据库相关 ...

随机推荐

  1. jquery元素使用

    特殊用法: var formFields = $([]).add(_ele1).add(_ele2);  可将多个元素整合到一个集合中 1.has方法 has()方法查找自己,has为子集条件,即包含 ...

  2. MySql.Data.MySqlClient连接MySql

    在C#中连接MySql数据库其实是件很简单的事情,但对于刚开始学习C#的朋友来说,问题却是不小,主要原因是相对于ACCESS和MSSql来说,MySql方面的教程文章实在太少,我也是自己摸索好好半天才 ...

  3. Crash 文件调试

    Xcode目录下执行 find . -name symbolicatecrash 找到symbolicatecrash位置,将其拷贝到debug用的文件夹下 执行命令 export DEVELOPER ...

  4. YCSB性能测试工具使用(转)

    在网上查In-Memory NoSQL性能测试的资料时,偶然间发现了这个性能测试工具YCSB,全称为“Yahoo! Cloud Serving Benchmark”.它内置了对常见NoSQL数据库和数 ...

  5. 【转】 DOTA2中的伪随机及其lua实现

    因为单纯的随机确实会影响到竞技性,所以dota2引入的是伪随机机制,在大量的技能中,比如说混沌的混乱之箭.剑圣的剑舞.冰女的冰霜领域之类的技能,都利用了伪随机机制. 而纯随机,或者标准正态分布并不会因 ...

  6. RH_KABI_RESERVE的使用

    struct mm_struct { .......... #if defined(__GENKSYMS__) || !defined(CONFIG_SPAPR_TCE_IOMMU) /* We're ...

  7. KVM虚拟化技术(四)安装虚拟机

    一.首先用比较简单的virt-manager来安装 # virt-manager 后面就是一般的安装系统流程了,这里不再复述 二.用virt-install命令行来安装 还是通过本地IOS文件来进行安 ...

  8. javaweb 学习系列【转】

    http://www.cnblogs.com/xdp-gacl/category/574705.html jsp指令 http://www.cnblogs.com/huiyuantang/p/5332 ...

  9. ubuntu去除带锁文件的锁 sudo chown 用户名 目标文件夹/ -R

    sudo chown 用户名 目标文件夹/ -R sudo chown han dir/ -R

  10. 如何查看Python对象的属性

    在Python语言中,有些库在使用时,在网络上找到的文档不全,这就需要查看相应的Python对象是否包含需要的函数或常量.下面介绍一下,如何查看Python对象中包含哪些属性,如成员函数.变量等,其中 ...