1、DjangoORM 建立基本类型及生成数据库表结构
一、简介
二、建立数据库 表结构
2、Django ORM基本增删改查
一、表数据增删改查
二、表结构修改
3、Django ORM 字段类型
一、字段类型介绍
二、字段参数介绍
三、Django ORM 外键操做html
ORM:关系对象映射。定义一个类自动生成数据库的表结构。python
建立数据库的时候,通常有如下几种经常使用数据类型:数字、字符串以及时间。mysql
ORM分为两种:git
主流的orm都是code first。django 的orm也是code first,因此学的时候,本质就分为两块:正则表达式
app下models.py文件:sql
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)
执行命令 python manage.py makemigrations
,会提示 No changes detected
,这是由于:执行命令时会找全部models,可是django不知道找哪一个,全部须要指定一下。数据库
settings.py,django
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直接生成数据库
执行后,从migrations便会产生操做记录。生成数据库,默认状况下用的sqlite3。能够用navicat等软件直接打开。缓存
db.sqlite3里面包含缓存、session、cookie、静态文件以及后台管理。像我们建立的表名叫:app01_userinfomarkdown
若是不使用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()
urls.py
url(r'^orm/', views.orm),
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':'lgeng', 'password':'666'} # models.UserInfo.objects.create(**dic) # 查询数据 # result = models.UserInfo.objects.all() # 查询全部,为QuerySet类型,可理解成列表 # result = models.UserInfo.objects.filter(username="lgeng",password="666") # 列表 # result = models.UserInfo.objects.filter(username="lgeng").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')
把最初定义的类中字段 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 字段类型中,有CharField、EmailField、URLField、GenericIPAddressField等,实际上在数据库里都是字符串。不能作检查语法,作不了验证。那这个有什么用呢?
这些是给Django 的 admin 用的。在admin那个网页上作验证。若是不用admin,那那些都是字符串,效果都同样。
自定义自增列:models.AutoField(primary_key=True)
一、models.AutoField 自增列 = int(11) 若是没有的话,默认会生成一个名称为 id 的列,若是要显示的自定义一个自增列,必须将给列设置为主键 primary_key=True。 2、models.CharField 字符串字段 必须 max_length 参数 三、models.BooleanField 布尔类型=tinyint(1) 不能为空,Blank=True 四、models.ComaSeparatedIntegerField 用逗号分割的数字=varchar 继承CharField,因此必须 max_lenght 参数 5、models.DateField 日期类型 date 对于参数,auto_now = True 则每次更新都会更新这个时间;auto_now_add 则只是第一次建立添加,以后的更新再也不改变。 6、models.DateTimeField 日期类型 datetime 同DateField的参数 七、models.Decimal 十进制小数类型 = decimal 必须指定整数位max_digits和小数位decimal_places 八、models.EmailField 字符串类型(正则表达式邮箱) =varchar 对字符串进行正则表达式 九、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正则表达式)(已弃用,用1三、) 13、models.GenericIPAddressField 字符串类型(ip4和ip6是可选的) 参数protocol能够是:both、ipv四、ipv6 验证时,会根据设置报错 14、models.NullBooleanField 容许为空的布尔类型 15、models.PositiveIntegerFiel 正Integer 16、models.PositiveSmallIntegerField 正smallInteger 17、models.SlugField 减号、下划线、字母、数字 18、models.SmallIntegerField 数字 数据库中的字段有:tinyint、smallint、int、bigint 1九、models.TextField 字符串=longtext 20、models.TimeField 时间 HH:MM[:ss[.uuuuuu]] 21、models.URLField 字符串,地址正则表达式 22、models.BinaryField 二进制 23、models.ImageField 图片 2四、models.FilePathField 文件
如上那么多的字段,可大体分为 字符串、数字、时间、二进制、自增(primary_key=True)几类。
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 # 更新时,自动更新为当前时间
# 更新时间(auto_now)不支持这种 obj = UserGroup.objects.filter(id=1).update(caption='CEO')
obj = UserGroup.objects.filter(id=1).first() # 自动更新时间须要这样写 obj.caption = "CEO" obj.save()
choices # 做用:一、django admin中显示下拉框;二、避免连表查询
user_type_choices = ( # 数据库只存一、二、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 用户
连表关系之一对多,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 = models.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 )
转载请务必保留此出处:http://www.cnblogs.com/lgeng/articles/7364356.html
<!-- EDD -->
《版权说明》: 本文转自 -- http://blog.csdn.net/fgf00/article/details/53678205