一、字段类型

二、字段选项说明

三、内嵌类参数说明
abstract = True
db_table = 'table_name' #表名,默认的表名是app_name+类名
ordering = ['id','-create_time'] #排序规则,按照哪个字段排序,加上负号是降序
unique_together = ('name','id_card') #联合主键
verbose_name = '用户表'#表的中文名
verbose_name_plural = '用户表'#表的中文名

四、同步到数据库
python manage.py makemigrations #生成迁移文件
python manage.py migrate #同步到数据库中

五、QuerySet增删改查
#创建
obj = models.Article.objects.create(title='title_model',desc='desc1',content='content')
obj.title = 'new_title'
obj.save()

obj2 = models.Article(title='title_model',desc='desc1',content='content')
obj2.save()

#查询
models.Article.objects.get(id=1)#单个查询,条件只能是唯一的,否则会报错
models.Article.objects.filter(title='xiaohei',desc='desc1')#多条件查询,返回多条数据,写多个参数就是and
models.Article.objects.all().filter(title='xiaohei').values()#字典显示
models.Article.objects.all().count()#个数
models.Article.objects.raw('select * from user_article;') # 执行原生sql
models.Article.objects.filter(title__contains='模糊查询')
models.Article.objects.filter(title__endswith='开头')
models.Article.objects.filter(title__startswith='结尾')
models.Article.objects.filter(title__in=['title1','title2'])
models.Article.objects.filter(title__isnull=True)#为空
models.Article.objects.exclude(title__in=['title1','title2'])#排除
models.Article.objects.filter(read_count__gt=1)
models.Article.objects.filter(read_count__gte=1)
models.Article.objects.filter(read_count__lt=1)
models.Article.objects.filter(read_count__lte=1)
models.Article.objects.filter(read_count__range=(1,2,3))

修改
art = models.Article.objects.get(pk=1)
art.title = 't1223'
art.save()

models.Article.objects.filter(title__isnull=True).update(title='小黑') #批量修改
models.Article.objects.all().update(title='全部修改')

删除
models.Article.objects.get(pk=1).delete()
models.Article.objects.filter(title__isnull=True).delete()
models.Article.objects.all().delete()

#外键操作
obj = models.Article.objects.get(id=1)
obj.nav_id = 2 #获取外键信息
print(obj.nav.name) #获取外键信息
models.Article.objects.filter(nav__name='abc') #按照外键的字段筛选,外键名称__字段名

反向查询
art_obj = models.Article.objects.get(pk=1)
nav_obj = models.Nav.objects.get(pk=2)
print(nav_obj.article_set.filter())#外键反向查询
print(nav_obj.article_set.count())#外键反向查询
nav_obj.article_set.add(art_obj)#添加
nav_obj.article_set.remove(art_obj)#删除
nav_obj.article_set.clear()#清空

多对多

models.CaseSet.objects.create(name='主流程用例',desc='主流程')
models.CaseSet.objects.create(name='冒烟用例',desc='冒烟用例')

models.Case.objects.create(title='登录')
models.Case.objects.create(title='注册')
models.Case.objects.create(title='订购')
models.Case.objects.create(title='支付')
models.Case.objects.create(title='充值')
models.Case.objects.create(title='发货')

c1 = models.Case.objects.get(pk=1)
c2 = models.Case.objects.get(pk=2)
c3 = models.Case.objects.get(pk=3)
s1 = models.CaseSet.objects.get(pk=1)
s2 = models.CaseSet.objects.get(pk=2)

s2.case_set.add(c2,c3)
s2.case_set.remove(c2,c3)
s2.case_set.clear()#清空

print(c2.case_set.all()) #查看用例在几个集合里面
print(s2.case_set.all()) #查看集合里面有多少用例

一对一
from hashlib import md5
models.Account.objects.create(account_id=md5('niuhanyang'.encode()).hexdigest())
models.Account.objects.create(account_id=md5('niuhanyang2'.encode()).hexdigest())
models.Account.objects.create(account_id=md5('niuhanyang3'.encode()).hexdigest())

models.User.objects.create(username='niuhanyang',password='123456',account_id='58e006ecfce801c5e98311c96d32510f')
u = models.User.objects.get(pk=1)
print(u.account_id)
print(u.account.money)

acc = models.Account.objects.get(pk='58e006ecfce801c5e98311c96d32510f')
print(acc.user.username)
print(acc.user.password)

表结构如下图:
一对一,user表和account表

nav表,外键,一对多

case表和case_set表

django->model模型操作(数据库操作)的更多相关文章

  1. Django1.11模型类数据库操作

    django模型类数据库操作 数据库操作 添加数据 1,创建类对象,属性赋值添加 book= BookInfo(name='jack',pub_date='2010-1-1') book.save() ...

  2. django Model模型二及Model模型对数据库的操作

    在django模型中负责与数据库交互的为Model层,Model层提供了一个基于orm的交互框架 一:创建一个最基本的Model from __future__ import unicode_lite ...

  3. 循序渐进Python3(十二) --2--  web框架之django简单实现oracle数据库操作

    在 Django 中构建 Oracle 数据库支持的 Web 应用程序 了解如何配置 Django 以便与 Oracle 数据库交互,并使用 ORM 进行数据库连接.             产能在软 ...

  4. django基础 -- 5. ORM 数据库操作

    一. ORM 对象关系映射 类   ------   表 类对象   ------   记录 类属性   ------   字段 二.  连接数据库配置 1.在  setting.py 文件中重新设置 ...

  5. Django入门4: ORM 数据库操作

    大纲 一.DjangoORM 创建基本类型及生成数据库表结构 1.简介 2.创建数据库 表结构 二.Django ORM基本增删改查 1.表数据增删改查 2.表结构修改 三.Django ORM 字段 ...

  6. ThinkPHP3创建Model模型--对表的操作

    创建Model模型 把"Home/Model"文件夹剪切到Application文件夹下,让Home和Admin共同使用. 第一种实例化模型的方法 第二种实例化模型的方法 第三种实 ...

  7. Django对于模型的数据操作

    一.引入模型的包 from myApp.models import Grades,Students 二.查询所有数据 #objecs是类的隐藏属性:类名.objects.all()可以查询所有数据 G ...

  8. Django框架----models.py(数据库操作文件)

    利用一个中间模块 帮助我们连接数据库,写SQL语句,执行SQL语句,拿到结果 models.py 一.数据的对应关系 1. 类 ---> 表 2. 对象 ---> 数据行 3. 属性 -- ...

  9. Django Model模型的实战操作笔记

    Model模型的实战操作笔记 1. 创建数据库和表 进入MySQL数据库创建数据库:mytest 进入数据库创建数据表:mytest_users CREATE TABLE `mytest_users` ...

  10. Django Model 模型

    参考: https://www.runoob.com/django/django-model.html https://www.cnblogs.com/taosiyu/p/11260000.html ...

随机推荐

  1. Python - 函数形参之必填参数、缺省参数、可变参数、关键字参数的详细使用

    Python函数形参 必传参数:平时最常用的,必传确定数量的参数 缺省参数:在调用函数时可以传也可以不传,如果不传将使用默认值 可变参数:可变长度参数 关键字参数:长度可变,但是需要以kv对形式传参 ...

  2. JavaScript每日学习日记(1)

    8.11.2019 1. lastIndexOf() 方法从尾到头进行检索. 2. 有三种提取部分字符串的方法: 2.1 slice(start, end)  如果某个参数为负,则从字符串的结尾开始计 ...

  3. 软件工程作业0——The Road Not Taken

    目录 第一部分:结缘计算机 缘起 四顾 思考 第二部分:在计算机系里学习 挑战 落差 第三部分:未来规划 向前 未来四个月的软工课 项目 内容 这个作业属于 2020春季计算机学院软件工程(罗杰 任健 ...

  4. CAS无锁模式

    一.java内存模型:JMM 在内存模型当中定义一个主内存,所有声明的实例变量都存在于主内存当中,主内存的数据会共享给所有线程,每一个线程有一个块工作内存,工作内存当中主内存数据的副本当更新数据时,会 ...

  5. Loadrunner 11安装和破解

    一.安装环境和文件准备 1.操作系统:Windows Server 2008 R2 Enterprise: 2.loadrunner版本:loadrunner 11: 3.安装浏览器:火狐39.0: ...

  6. 死磕Lambda表达式(五):Comparator复合

    给岁月以文明,而不是给文明以岁月.--<三体> 在上一篇文章(传送门)中介绍了JDK为我们提供的常用函数式接口,JDK不仅提供的这些函数式接口,其中一些接口还为我们提供了实用的默认方法,这 ...

  7. upload-labs通关集

    upload-labs通关集 环境 第一题 前端js检查 第二题 content-type类型绕过 第三题 黑名单绕过 第四题 .htaccess绕过 第五题 大小写绕过 第六题 空格绕过 第七题 点 ...

  8. PS2手柄在arduino上进行测试,可用,供喜欢diy的朋友借鉴

    #include <PS2X_lib.h> //PS2手柄PS2X ps2x; // create PS2 Controller Class//////////PS2引脚///////// ...

  9. DOM 操作成本到底高在哪儿?

    从我接触前端到现在,一直听到的一句话:操作DOM的成本很高,不要轻易去操作DOM.尤其是React.vue等MV*框架的出现,数据驱动视图的模式越发深入人心,jQuery时代提供的强大便利地操作DOM ...

  10. PHP7内核(四):生命周期之开始前的躁动

    上一章我们对PHP的源码目录结构有了初步了解,本章我们继续从生命周期的维度对PHP进行剖析. 一.概览 生命周期是什么呢?你可以把它看作执行过程,PHP的生命周期也就是它从开始执行到结束执行的过程. ...