单表操作

增加数据

    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. ABAP-异常捕获

    异常处理 基于类的异常exception classes 捕获 使用老式方式捕获catchable runtime errors 向上抛出异常 手动触发异常(类异常) 6.1版本以后,TRY…ENDT ...

  2. WDA-2-事件执行先后

    WebDynpro 中事件执行顺序 一:WebDynpro 启动时的 hokeMethod 执行顺序 (这里观察一个 view)从上至下,依次进行 如果这个 view 上还有一个 button(能触发 ...

  3. Grafana+Zabbix使用配置

    官方提供的网友分享的图形面板,可以自行选择使用下载---  https://grafana.com/dashboards   Grafana 是 Graphite 和 InfluxDB 仪表盘和图形编 ...

  4. CHAR 和VARCHAR的区别

    CHAR(10)是不可变长度为10的字符串,占的存储空间始终为10个字符的长度,而VARCHAR(10)是可变长度的字符串,故而可以节省空间.例如:储存"aaaaabbbbb",则 ...

  5. IDEA 中的一些概念变化

    IntelliJ系中的Project相当于Eclipse系中的workspace. IntelliJ系中的Module相当于Eclipse系中的Project. idea中只能配置一个maven,而且 ...

  6. 【deep learning】斯坦福CS231n—深度学习与计算机视觉(资料汇总)

    官网 链接:CS231n: Convolutional Neural Networks for Visual Recognition Notes: 链接:http://cs231n.github.io ...

  7. mysql 5.7.3.0-m13安装教程

    安装mysql百度经验地址:(默认安装,除了选择不更新和选择保存路径,其它基本是下一步下一步) http://jingyan.baidu.com/article/7e440953d6f0702fc1e ...

  8. Redis集群模式部署

    以下以Linux(CentOS)系统为例 1.1 下载和编译 $ wget http://download.redis.io/releases/redis-4.0.7.tar.gz $ tar xzf ...

  9. scala spark 聚类

    import org.apache.spark.ml.clustering.KMeansimport org.apache.spark.ml.evaluation.ClusteringEvaluato ...

  10. hive sql 效率提升

    转 :  http://www.cnblogs.com/xd502djj/p/3799432.html hive的查询注意事项以及优化总结 . Hive是将符合SQL语法的字符串解析生成可以在Hado ...