Django的orm一

1.创建表

1.1 创建普通表

class UserType(models.Model):
'''
用户类型
'''
title=models.CharField(max_length=16)

1.2 创建外键依赖

class UserInfo(models.Model):
'''
用户表
'''
username=models.CharField(max_length=16)
age=models.IntegerField()
ut=models.ForeignKey('UserType',on_delete=models.CASCADE)

不指定主键的类,在执行命令的时候会直接同步出一列id字段;

1.3 修改表

  • 增加表,直接添加类
  • 注意此时,数据库中若是有数据需要允许为空(或者设置默认值defualt)
class Foo(models.Model):
name=models.CharField(max_length=16) class UserType(models.Model):
'''
用户类型
'''
title=models.CharField(max_length=16)
uf=models.ForeignKey(to='Foo',on_delete=models.CASCADE)

1.4 常用字段

# 字符串
models.CharFiled(max_length=?)
# 整数型
models.IntegerField()
# 布尔值字段
models.BooleanField(verbose_name='别名每个类型都可以有', default=False)#默认值
# 时间类型
models.DateTimeField(verbose_name='创建时间', auto_now_add=True)#设置自动添加
# 大整数
models.BigIntegerField()
# 正整数
models.PositiveIntegerField(verbose_name='价格')
# 小数值-存储的一般是0-9的单个值,代表对应的值
models.SmallIntegerField()
# 外键
models.ForeignKey(to="表",on_delete=models.CASCADE)
 category_choices = (
(1, '免费版'),
(2, '收费版'),
(3, '其他'),
)
category = models.SmallIntegerField(verbose_name='收费类型', default=2, choices=category_choices)
models.DateTimeField(verbose_name='开始时间', null=True, blank=True)
  • blank

    设置为True时,字段可以为空。设置为False时,字段是必须填写的。字符型字段CharField和TextField是用空字符串来存储空值的。如果为True,字段允许为空,默认不允许。

  • null

    设置为True时,django用Null来存储空值。日期型、时间型和数字型字段不接受空字符串。所以设置IntegerField,DateTimeField型字段可以为空时,需要将blank,null均设为True

2. 执行命令

# 1.生成记录的名称
python manage.py makemigrations # 2.生成到数据库中的命令
python manage.py migration

生成的记录文件在对应的APP的migrations文件夹下;

3.插入数据

# 插入数据
models.UserType.objects.create(title="1")
models.UserType.objects.create(title="2")
models.UserType.objects.create(title="3")
models.UserInfo.objects.create(username="逻辑",age="30",ut_id="1")#数据库中的外键,为ut_id
models.UserInfo.objects.create(username="程心",age="35",ut_id="1")
models.UserInfo.objects.create(username="艾AA",age="27",ut_id="2")
models.UserInfo.objects.create(username="曼努尔·雷迪亚兹",age="30",ut_id="3")

4.简单查询

4.1 查询所有

res=models.UserInfo.objects.all()
print(res)

返回的是对象类型QuerySet(类似列表),包含很多对象,一个对象就是一行数据;

  • 循环显示

  • res=models.UserInfo.objects.all()
    print(res)
    for row in res:
    print(row.id,row.username)

4.2 条件查询

res_list=models.UserInfo.objects.filter(id=1,username="逻辑")#默认是and连接的
print(res_list[0].username)

4.3 简单介绍双下划线

  • gt大于;lt小于
  • res_list=models.UserInfo.objects.filter(id__gt=2)#查找id大于2的
    res_list1=models.UserInfo.objects.filter(id__lt=2)#查找id小于2的

5.删除数据

  • models.UserInfo.objects.filter(id=4).delete()

6.更改数据

models.UserInfo.objects.filter(id=3).update(age=18)

8.连表查询

8.1 正向操作

  • 包含外键字段的表,直接使用表可以找出关联表的对应数据行(一条);
reslist=models.UserInfo.objects.all()
for res in reslist:
print(res.username,res.age,res.ut_id,res.ut)#两张表连接
# print(res.ut)#对象,代表usertype中的一行数据
# print(res.ut.title)
# print(res.ut.uf)#uf的对象
# print(res.ut.uf_id)#uf的对象
# print(res.ut.uf.name)#uf的对象,连接到第三张表
return HttpResponse("Hello world")

8.2反向操作

  • 被关联的表,不包含外键的字段;但是可以使用,表名小写_set,取出对应的值与数据(多条);
obj=models.UserType.objects.all().first()#取得第一条数据
print(obj.title,obj.userinfo_set)
for row in obj.userinfo_set.all():
print(row.username,row.age)
# 待条件的反向操作
reslist=models.UserType.objects.all()
for item in reslist:
print(item.title,item.userinfo_set.filter(username="逻辑"))

9.返回值

9.1 Values

  • 返回的QuerySet内部是字典类型;
res=models.UserInfo.objects.all().values('id','username')
# res依旧是queryset但是内部是字典类型
print(res)
for item in res:
print(item)

9.2 Values_list

  • 返回的QuerySet内部类型是元组
res_list=models.UserInfo.objects.all().values_list('id','username')
# 取出的依旧是两列,内部是列表类型
for res in res_list:
print(res)

9.3返回值总结

  • 返回对象
    models.Userinfo.objects.all()
    models.Userinfo.objects.filter(id__gt=1)# id>1

    返回的对象可以使用.进行操作

  • 返回字典
    models.Userinfo.objects.all().values('id','username')# 填入对应的值
  • 返回元组
    models.Userinfo.objects.all().values_list('id','username')# 填入对应的值

  • 注意:字典和元组不能像对象一样进行跨表因此跨表的时候需要在传入对应的参数,使用双下划线

    # 跨表字段使用双下滑线进行操作;元组中也是这样;
    res=models.UserInfo.objects.all().values('id','username','ut__title')
    # res依旧是queryset但是内部是字典类型
    print(res)
    for item in res:
    print(item)

继续努力,终成大器;

Django的orm(一)的更多相关文章

  1. python——Django(ORM连表操作)

    千呼万唤始出来~~~当当当,终于系统讲了django的ORM操作啦!!!这里记录的是django操作数据库表一对多.多对多的表创建及操作.对于操作,我们只记录连表相关的内容,介绍增加数据和查找数据,因 ...

  2. Python’s SQLAlchemy vs Other ORMs[转发 3]Django's ORM

    Django's ORM Django is a free and open source web application framework whose ORM is built tightly i ...

  3. 将SALT_STACK的JOB-CACHE放到数据库中,而建库用DJANGO的ORM完成

    下面包括了SALT_MASTER的配置,及DJANGO的ORM里更改默认表名称,更改默认字段名称(里面有个RETURN),更改默认ID索引... 一个下午有和它磨来磨去... 感谢鹏龙,感谢高远..: ...

  4. Django:之ORM、CMS和二维码生成

    Django ORM Django 的数据库接口非常好用,我们甚至不需要知道SQL语句如何书写,就可以轻松地查询,创建一些内容,所以有时候想,在其它的地方使用Django的 ORM呢?它有这么丰富的 ...

  5. Django的ORM实现数据库事务操作

    在Django中实现数据库的事务操作 在学习MySQL数据库时,MySQL数据库是支持原子操作的. 什么是数据库的原子操作呢??打个比方,一个消费者在一个商户里刷信用卡消费. 交易正常时,银行在消费者 ...

  6. 第十九章 Django的ORM映射机制

    第十九章 Django的ORM映射机制 第一课 Django获取多个数据以及文件上传 1.获取多选的结果(checkbox,select/option)时: req.POST.getlist('fav ...

  7. Django之ORM基础

    ORM简介 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...

  8. Django中ORM介绍和字段及其参数

    ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...

  9. ORM以及Django使用ORM创建表

    day61 2018-04-28 1. 内容回顾 1. HTTP协议消息的格式: 1. 请求(request) 请求方法 路径 HTTP/1.1\r\n k1:v1\r\n ...\r\n \r\n ...

  10. django的ORM

    在项目根目录下运行 python manage.py shell 即可进入django的交互shell界面 查询 from my_app.models import MyTestModel datas ...

随机推荐

  1. pwnkit漏洞分析-CVE-2021-4034

    研究了一下前段时间的Polkit提权漏洞,里面有很多以前不知道的技巧.漏洞很好用,通杀CENTOS.UBUNTU各版本. 主要是分析这个POC触发原理.POC如下: /* * Proof of Con ...

  2. python 小兵(4)之文件操作 小问题

    1.光标不对就用seek 2.文件操作方面注意不要变修改变删除,会爆出文件正在运行不能操作 3.w模式下只有开始打开的时候会清空 4.文件操作的时候用as 后面的参数进行操作,不能用文件名进行操作 5 ...

  3. ApacheCN Python 译文集 20211108 更新

    Think Python 中文第二版 第一章 编程之路 第二章 变量,表达式,语句 第三章 函数 第四章 案例学习:交互设计 第五章 条件循环 第六章 有返回值的函数 第七章 迭代 第八章 字符串 第 ...

  4. Nginx实现跨域配置详解

    主要给大家介绍了关于Nginx跨域使用字体文件的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍: 问题描述 今天在使用子域名访问根域名的CSS时,发现字体无法显示,在确保CSS和Font字 ...

  5. curl: (6) Could not resolve host: mirrors.163.com; Unknown error 服务器上解析不了域名,换成ip可以

    原因是DNS域名解析问题: 添加nameserver即可解决 echo nameserver 8.8.8.8 > /etc/resolv.conf 解释一下DNS服务 DNS(Domain Na ...

  6. Docker部署lnmp 实战 (多注意配置文件,不管访问试试换个浏览器)

    Docker部署LNMP环境 关闭防火墙,设置自定义网络 systemctl stop firewalld systemctl disable firewalld setenforce 0 docke ...

  7. k8s之Dashboard插件部署及使用

    k8s之Dashboard插件部署及使用 目录 k8s之Dashboard插件部署及使用 1. Dashboard介绍 2. 服务器环境 3. 在K8S工具目录中创建dashboard工作目录 4. ...

  8. (Elementui) el-tree 中英文过滤以及搜索到父子显示子节点,搜索到子节点显示父节点(filter-node-method)

    案例下载:https://gitee.com/tudoumlp/just1.git   (vue-ele-demo) 在项目中,会遇到树节点的搜索,中文和英文搜索,以及搜索到父节点匹配的时候同步显示该 ...

  9. requests库session保持持久会话

      requests中cookie的原理 http://blog.csdn.net/zhu_free/article/details/50563756   requests - cookies的实现例 ...

  10. Solution -「NOI 2012」「洛谷 P2050」美食节

    \(\mathcal{Description}\)   Link.   美食节提供 \(n\) 种菜品,第 \(i\) 种的需求量是 \(p_i\),菜品由 \(m\) 个厨师负责制作,第 \(j\) ...