Django ORM 数据库操作

比较有用

转自 http://blog.csdn.net/fgf00/article/details/53678205

一、DjangoORM 创建基本类型及生成数据库表结构
1、简介
2、创建数据库 表结构
二、Django ORM基本增删改查
1、表数据增删改查
2、表结构修改
三、Django ORM 字段类型
1、字段类型介绍
2、字段参数介绍
3、Django ORM 外键操作

一、DjangoORM 创建基本类型及生成数据库表结构

1、简介

ORM:关系对象映射。定义一个类自动生成数据库的表结构。

创建数据库的时候,一般有以下几种常用数据类型:数字、字符串以及时间。

ORM分为两种:

DB First 数据库里先创建数据库表结构,根据表结构生成类,根据类操作数据库
Code First 先写代码,执行代码创建数据库表结构
主流的orm都是code first。django 的orm也是code first,所以学的时候,本质就分为两块:

根据类自动创建数据库表
根据类对数据库表中的数据进行各种操作
2、创建数据库 表结构

先写类:
app下models.py文件:

from django.db import models

class UserInfo(models.Model): # 必须继承models.Model
# 不写则,django默认创建ID列,自增,主键
# 用户名列,字符串类型,指定长度
username = models.CharField(max_length=32)
password = models.CharField(max_length=64)

注册APP
执行命令python manage.py makemigrations,会提示No changes detected,这是因为:执行命令时会找所有models,但是django不知道找哪个,所有需要指定一下。

settings.py,

INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01', # 这里添加app
]

执行命令生成表结构
python manage.py makemigrations # 生成migrations临时文件
python manage.py migrate # 根据migrations直接生成数据库
1
2
执行后,从migrations便会产生操作记录。生成数据库,默认情况下用的sqlite3。可以用navicat等软件直接打开。

db.sqlite3里面包含缓存、session、cookie、静态文件以及后台管理。像咱们创建的表名叫:app01_userinfo

连接mysql数据库
如果不使用sqlite,使用mysql数据库。代码不用改、命令也不用改,只需要改下配置文件。

# https://docs.djangoproject.com/en/1.10/ref/settings/#databases 官网文档
# DATABASES = { # sqlite 默认
# 'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
# }
# }
DATABASES = { # mysql
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'mydatabase',
'USER': 'mydatabaseuser',
'PASSWORD': 'mypassword',
'HOST': '127.0.0.1',
'PORT': '3306',
}
}

注意:

数据库名django不能创建,需要自己提前创建

Django默认使用MySQLdb模块链接MySQL,但python3现在还没有MySQLdb,所以改为用pymysql去连。在project项目名下的__init__.py里面

import pymysql
pymysql.install_as_MySQLdb()
1
2
二、Django ORM基本增删改查

1、表数据增删改查

urls.py

url(r'^orm/', views.orm),
1
app01/views.py

from app01 import models # 导入models模块
def orm(request):
# 创建数据
# 第一种方式
# models.UserInfo.objects.create(username="root",password="123")
# 第二种方式
# obj = models.UserInfo(username='fzh', password="iajtag")
# obj.save()
# 第三种方式
# dic = {'username':'fgf', 'password':'666'}
# models.UserInfo.objects.create(**dic)

# 查询数据
# result = models.UserInfo.objects.all() # 查询所有,为QuerySet类型,可理解成列表
# result = models.UserInfo.objects.filter(username="fgf",password="666") # 列表
# result = models.UserInfo.objects.filter(username="fgf").first() # 对象
# 条件查询。filter 相当于where查询条件,里面的","会组成and条件
# for row in result: # 打印查询到数据。
# print(row.id,row.username,row.password)

# 查看QuerySet类型具体做了什么事情,可以: print(result.query)

# 删除数据
# models.UserInfo.objects.all().delete() # 删除所有
# models.UserInfo.objects.filter(id=4).delete() # 删除所有

# 更新数据
# models.UserInfo.objects.all().update(password=8888)
# models.UserInfo.objects.filter(id=3).update(password=888888)

return HttpResponse('orm')

2、表结构修改

修改列
把最初定义的类中字段password = models.CharField(max_length=64)改为password = models.CharField(max_length=60)。重新执行python manage.py makemigrations,python manage.py migrate,则数据表结构更改了。如果列内内容超过定义大小,则数据就丢了。

增加一列
类中增加一列,执行命令,会有提示信息,因为默认情况下是不允许为空的。这里提供两个选项。

输入一个值,新增列已存在的行默认加上输入的内容。
email = models.CharField(max_length=32, null=True),允许为空
查看表结构变化时,刷新看不出来,需要重新打开表看效果。

删除列
类内删掉相应的字段,执行命令即可。

三、Django ORM 字段类型

1、字段类型介绍

Django ORM 字段类型中,有CharField、EmailField、URLField、GenericIPAddressField等,实际上在数据库里都是字符串。不能做检查语法,做不了验证。那这个有什么用呢?

这些是给Django 的 admin 用的。在admin那个网页上做验证。如果不用admin,那那些都是字符串,效果都一样。

自定义自增列:models.AutoField(primary_key=True)

1、models.AutoField  自增列 = int(11)
  如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自定义一个自增列,必须将给列设置为主键 primary_key=True。
2、models.CharField  字符串字段
  必须 max_length 参数
3、models.BooleanField  布尔类型=tinyint(1)
  不能为空,Blank=True
4、models.ComaSeparatedIntegerField  用逗号分割的数字=varchar
  继承CharField,所以必须 max_lenght 参数
5、models.DateField  日期类型 date
  对于参数,auto_now = True 则每次更新都会更新这个时间;auto_now_add 则只是第一次创建添加,之后的更新不再改变。
6、models.DateTimeField  日期类型 datetime
  同DateField的参数
7、models.Decimal  十进制小数类型 = decimal
  必须指定整数位max_digits和小数位decimal_places
8、models.EmailField  字符串类型(正则表达式邮箱) =varchar
  对字符串进行正则表达式
9、models.FloatField  浮点类型 = double
10、models.IntegerField  整形
11、models.BigIntegerField  长整形
  integer_field_ranges = {
    'SmallIntegerField': (-32768, 32767),
    'IntegerField': (-2147483648, 2147483647),
    'BigIntegerField': (-9223372036854775808, 9223372036854775807),
    'PositiveSmallIntegerField': (0, 32767),
    'PositiveIntegerField': (0, 2147483647),
  }
12、models.IPAddressField  字符串类型(ip4正则表达式)(已弃用,用13、)
13、models.GenericIPAddressField  字符串类型(ip4和ip6是可选的)
  参数protocol可以是:both、ipv4、ipv6
  验证时,会根据设置报错
14、models.NullBooleanField  允许为空的布尔类型
15、models.PositiveIntegerFiel  正Integer
16、models.PositiveSmallIntegerField  正smallInteger
17、models.SlugField  减号、下划线、字母、数字
18、models.SmallIntegerField  数字
  数据库中的字段有:tinyint、smallint、int、bigint
19、models.TextField  字符串=longtext
20、models.TimeField  时间 HH:MM[:ss[.uuuuuu]]
21、models.URLField  字符串,地址正则表达式
22、models.BinaryField  二进制
23、models.ImageField 图片
24、models.FilePathField 文件

如上那么多的字段,可大致分为 字符串、数字、时间、二进制、自增(primary_key=True)几类。

2、字段参数介绍

数据库中的字段参数
null # 是否可以为空
default # 默认值
primary_key # 主键
db_column # 列名
db_index # 索引(db_index=True)
unique # 唯一索引(unique=True)
unique_for_date # 只对日期索引
unique_for_month # 只对月份索引
unique_for_year # 只对年做索引
auto_now # 创建时,自动生成时间
auto_now_add # 更新时,自动更新为当前时间

# 更新时间不支持这种
obj = UserGroup.objects.filter(id=1).update(caption='CEO')
obj = UserGroup.objects.filter(id=1).first() # 自动更新时间需要这样写
obj.caption = "CEO"
obj.save()

以下是只针对admin的字段参数
choices # 作用:1、django admin中显示下拉框;2、避免连表查询
1
user_type_choices = ( # 数据库只存1、2、3,后面的信息存在内存里。
(1, '超级用户'),
(2, '普通用户'),
(3, '普普通用户'),
)
user_type_id = models.IntegerField(choices=user_type_choices,default=1)

blank # django admin是否可以为空
verbose_name # django admin显示字段中文
editable # django admin是否可以被编辑
error_messages # 错误信息
# error_messages={"required":"密码不能为空",} # 注意必须有逗号
help_text # django admin提示
validators # django form ,自定义错误信息

python manage.py createsuperuser # 创建 Django 用户

3、Django ORM 外键操作

连表关系之一对多,models.ForeignKey(ColorDic)

models.py

表关联
class UserGroup(models.Model):
uid = models.AutoField(primary_key=True)
caption = models.CharField(max_length=32,unique=True)
ctime = models.DateTimeField(auto_now_add=True, null=True)
uptime = models.DateTimeField(auto_now=True, null=True)

class UserInfo(models.Model):
username = models.CharField(max_length=32,blank=True,verbose_name='用户名')
password = models.CharField(max_length=60, help_text='pwd')
email = models.CharField(max_length=60)
test = models.EmailField(max_length=19,null=True,error_messages={'invalid': '请输入密码',})
# UserInfo表中没有user_group字段,而是 user_group_id 列 值为 uid 数字
user_group = models.ForeignKey("UserGroup",to_field='uid') # 外键关联 **********

数据查询
user_list = Userinfo.objects.all() # 获取Userinfo对象
for row in user_list: #
print(row.user_group_id) # 数据库里真实存在的数据
# user_group:代指UserGroup对象。类UserGroup对象里封装了(uid,catption,ctime,uptime)
print(row.user_group.uid) # 通过对象获取uid,和user_group_id一样
print(row.user_group.caption) # 通过对象获取caption

创建数据
UserInfo表创建数据,怎么写呢?

models.UserInfo.objects.create(
username='root1',
password='123',
email="asdfasdf",
test="asdfasdf",
# 第一种方式:再次查询数据库,不推荐
# user_group = models.UserGroup.objects.filter(id=1).first()
# 第二种方式:通过 外键字段_id
user_group_id = 1
)

 

 

 

null -> db是否可以为空
default -> 默认值
primary_key -> 主键
db_column -> 列名
db_index -> 索引
unique -> 唯一索引
unique_for_date ->
unique_for_month
unique_for_year
auto_now -> 创建时,自动生成时间
auto_now_add -> 更新时,自动更新为当前时间

# obj = UserGroup.objects.filter(id=1).update(caption='CEO')
# obj = UserGroup.objects.filter(id=1).first()
# obj.caption = "CEO"
# obj.save()

choices -> django admin中显示下拉框,避免连表查询
blank -> django admin是否可以为空
verbose_name -> django admin显示字段中文
editable -> django admin是否可以被编辑
error_messages -> 错误信息欠
help_text -> django admin提示

 

新建和更新时间字段

ctime = models.DateTimeField(auto_now_add=true,null=true)

uptime = models.DateTimeField(auto_now=true,null=true)

 

 

 

 

 模板中这种用row.b__caption 来获取值

转载于:https://www.cnblogs.com/testway/p/7552521.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/487559.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI芯片的另一条路

来源:半导体行业观察在先进工艺和架构的协同下,芯片的性能在过去几年获得了爆发性的增长,尤其是在最近几年火热的人工智能行业,这个取得的成就是有目共睹的。据OpenAI在2018年年中发表的报告,自 2012 年以来&#xff0…

JavaScript之event事件

目录 1:事件驱动1 2:事件分类2 3:事件对象event3 4:关于鼠标事件对象属性3 应用:5 5:关于键盘事件对象的属性6 6:目标事件源对象7 7. 事件冒泡7 应用:8 CSS模拟下拉菜单。8 综合应用…

四大全球卫星导航系统都能提供什么服务?

来源:远望智库预见未来远望智库特约专家 陈刘成卫星导航系统是人类发明的最为重要的时间和空间测量工具。没有测量就没有科学,没有测量就没有管理。卫星导航系统价值集中体现在帮助人类精确感知、认知、控制物质、能量、信息的时空运行与分布。目前已经建…

一文了解72名图灵奖获得者的成就

来源:图灵教育今天是计算机科学之父、人工智能之父 艾伦麦席森图灵 诞辰 108 周年。作为“图灵意志”的传承者,依照惯例,在今日纪念这位伟人。从“图灵机”到“图灵测试”,从破译德军的 Enigma 到自杀之谜,图灵一生都是…

安卓修改wifi已停用_手机连不上wifi显示已保存怎么回事【原因介绍】

问:为什么手机连不上wifi显示已保存?手机在连接WiFi的时候,WiFi显示已保存,手机连接不上wifi信号。请问这是什么原因引起的,应该怎么解决这个问题。答:如果手机连接wifi时,显示已保存,手机连接…

机器人智能抓取系统:目前几种主流的解决方案

文章来源:COBOT机器人大脑、新机器视觉机器人学习中的经典问题之一便是分拣:在一堆无序摆放的物品堆中,取出目标物品。在快递分拣员看来,这几乎是一个不需要思考的过程,但对于机械臂而言,这意味着复杂的矩阵…

bzoj1018 [SHOI2008]堵塞的交通traffic

题目链接 分析: 这道题的题解很长,所以就不粘题面了,我们一点一点讲明白这道题 很荣幸,我看了题面之后 想到了这道题 可以很高兴的发现10w是线段树能够承受的范围 我们可以利用线段树维护连通性,每个节点内我们要维…

Science重磅!人类特有基因触发猴子长出更强大的大脑

本文系生物谷原创编译,欢迎分享,转载须授权!人类大脑在进化过程中的扩张,特别是新大脑皮层的扩张,与诸如推理和语言等认知能力有关。有一种叫做ARHGAP11B的基因,只在人类身上表达,它能触发大脑干…

『实践』Matlab实现Flyod求最短距离及存储最优路径

Matlab实现Flyod求最短距离及存储最优路径 一、实际数据 已知图中所有节点的X、Y坐标。 图中的节点编号:矩阵中的编号 J01-J62:1-62; F01-F60:63-122; Z01-Z06:123-128; D01-D02:129-130. 二、Floyd求所有节点间的最小距离及通过矩阵存储最优路径的节点 1 function …

MIT Technology Review 2020年“十大突破性技术”解读 【中国科学基金】2020年第3期发布...

来源:国家自然科学基金委员会MIT Technology Review 2020年“十大突破性技术”解读[编者按] 2020年2月26日,MIT Technology Review一年一度的“十大突破性技术”榜单正式发布。自2001年起,该杂志每年都会评选出当年的…

大数据是怎么知道你去过新发地的?

来源:科学加(北京科技报记者:赵天宇)“经过全市大数据分析,您可能在5月30日(含)以后去过新发地批发市场……”随着新发地市场新冠源头被锁定,近日来,大数据筛查,成为不少北京市民在朋…

口罩巨头挑战“量子霸权”,3个月造出的『最强量子计算机』靠谱不?

摘要霍尼韦尔(Honeywell)最近可是非常忙活。作为全球数一数二的口罩厂商,疫情期间霍尼韦尔一直在努力生产口罩,大家对它的印象也多停留在口罩生产者的层面。但是事实上,人家是正经的多元化高科技制造企业,航空产品、汽车产品、涡轮…

三极管稳压管组成的线性电源关键理解

1. A点电压为20V.B点电压是稳压管电压5.6V.则A到B的电流是固定的。 2. 加电后在调整三极管,负载, 稳压管的电流回路如图。(注意电流方向,a->b电流方向和大小都是基本不变的。) 转载于:https://www.cnblogs.com/ture…

oci连接mysql_使用 OCILIB 连接并操作 Oracle 数据库

OCILIB是一个跨平台的Oracle驱动程序,可提供非常快速和可靠地访问Oracle数据库。它提供了一个丰富,功能齐全,并易于使用的APIOCILIB是一个跨平台的Oracle驱动程序,,可提供非常快速和可靠地访问Oracle数据库。它提供了一…

万字长文:2020智源大会总结-多角度看AI的未来

来源:混沌巡洋舰导读:智源大会2020 聚焦AI的未来,大家都知道, 2010是深度学习的时代, 我们经历了AI从巅峰进入到瓶颈的过程。那么什么是2020这个十年AI的中心?近一段大家逐步从各个不同的角度切入到这个主题…

python OCR 图形识别

1、pip install pyocr 2、pip install PIL 3、安装tesseract-ocr http://jaist.dl.sourceforge.net/project/tesseract-ocr-alt/tesseract-ocr-setup-3.02.02.exe exe文件,下载后直接安装,建议默认安装过程中的选项,安装目录默认C:\Program F…

python生成文件夹并向文件夹写文件_python - 文件练习生成100个MAC地址写入文件

需求:生成100个MAC地址并写入文件中,MAC地址前6位(16进制)为01-AF-3B解题思路:要求生成这样格式的mac地址:01-AF-3B-xx-xx-xx首先生成-xx格式,16进制组成的数,注意MAC英文字母为大写。拼接成为:01-AF-3B-xx…

智能发展与双重建构

来源: 人机与认知实验室本文摘自1983.5《国内哲学动态》皮亚杰有关同化和顺应及其平衡的图式学说是对智慧机制的一种结构主义的共时性分析,但是他更重视对智慧机制进行建构主义的历时性研究。主体关于客体的知识以及主体自身的认识图式都不仅仅是一种状态体系 , 而首…

前途无量的MEMS传感器

来源:转载自「民生证券」,谢谢微机电系统(Microelectromechanical Systems,简称 MEMS)是将微电子技术与精密机械技术结合发展出来的工程技术,尺寸在 1 微米到 100 微米量级,涵盖机械&#xff08…

【技术趋势】德勤发布2020技术趋势报告,五个新趋势可引发颠覆性变革

来源:产业智能官“2020 年的趋势将颠覆整个行业,并在未来十年重新定义业务,即使数字创新已成为各种规模企业的常规行为。”德勤管理咨询新兴技术研究总监兼政府及公共服务首席技术官 Scott Buchholz 在一份报告中如是说。近日,《德…