单表操作

增加数据

    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. 现学现卖——VS2013 C#测试

    VS2013 C#测试 首先安装Unit Test Generator.方法为:工具->扩展和更新->联机->搜索“Unit Test Generator”,图标为装有蓝色液体的小试 ...

  2. Python基础-TypeError:takes 2 positional arguments but 3 were given

    Error: 今天写一段简单类定义python代码所遇到报错问题:TypeError: drive() takes 2 positional arguments but 3 were given 代码 ...

  3. Haskell语言学习笔记(80)req

    req req 是一个好用,类型安全,可扩展,上层的HTTP客户端的库. $ cabal install req Installed req-1.1.0 Prelude> :m +Network ...

  4. Linux tr命令使用方法

    tr命令主要用于删除文件中控制字符或进行字符转换.本文主要介绍tr命令的基本语法和使用实例. tr基本语法 tr命令格式:tr [ -d ] [ -c ] [ -s ] [ 字符串1 ] [ 字符串2 ...

  5. python实现排序算法一:快速排序

    ##快速排序算法##基本思想:分治法,将数组分为大于和小于该值的两部分数据,然后在两部分数据中进行递归排序,直到只有一个数据结束## step1: 取数组第一个元素为key值,设置两个变量,i = 0 ...

  6. python小实例一:简单爬虫

    本文所谓的爬虫就是通过本地远程访问url,然后将url的读成源代码形式,然后对源代码进行解析,获取自己需要的数据,相当于简单数据挖掘.本文实现的是将一个网页的图片爬出保存到本地的过程,例子很简单,用的 ...

  7. 四则运算3+PSP

    题目要求: 1.要求在第二次实验(四则运算2)的基础上加上其他功能. 2.要求能够在每个运算式打印出来后,用户能够进行输入计算的答案,并且程序进行判断给出用户输入的答案的正确性. 3.要求实现四则混合 ...

  8. C# DataTable使用方法详解--删除表数据

    在项目中常常常使用到DataTable,假设DataTable使用得当,不仅能使程序简洁有用,并且可以提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结. 1.添加引用 1 u ...

  9. python 任务调度模块sched

    类似于crontab的功能,可以实现定时定点执行任务; 将已经生成的任务放入队列中,获取到了执行可以实现任务调度功能; 如果将需求复杂化,加上优先级策略,并能取消已经加入队列中的任务,就需要使用pyt ...

  10. python第三步骤(pygame)

    1:先安装homebrew(类似于yum /apt-get为什么需要它呢,因为pip安装的时候需要很多的包的依赖,sdl什么的), 2:pip 安装pygame 我讨厌的环境变量问题 然后 通过的是 ...