0、数据库配置
django默认支持sqlite,mysql, oracle,postgresql数据库。Django连接数据库默认编码使用UTF8,使用中文不需要特别设置。
sqlite
django默认使用sqlite的数据库,默认自带sqlite的数据库驱
引擎名称:django.db.backends.sqlite3
mysql
引擎名称:django.db.backends.mysql
mysql引擎配置:
'defaults': {
'ENGINE': 'django.db.backends.mysql',
'NAME':'127.0.0.1',
'USER':'root',
'PASSWORD':'',
}
mysql引擎底层驱动的py3支持问题:
mysql驱动程序 MySQLdb(mysql python),Django默认使用改驱动,但改驱动在python3下存在兼容性问题。因此使用PyMySQL。 PyMySQL(纯python的mysql驱动程序) mysql驱动python3解决方法 找到项目名文件下的__init__,在里面写入: import pymysql pymysql.install_as_MySQLdb()
一、Model类定义
1、Model类创建
下面这个模型类将作为本篇博客的基础模型,所有的实例都基于此。
from django.db import models class Publisher(models.Model): name = models.CharField(max_length=30, verbose_name="名称") website = models.URLField() # book_set 反向关联一对多字段的Book def __unicode__(self): return self.name class Author(models.Model): name = models.CharField(max_length=30) # authordetail 反向关联一对一字段AuthorDetail表 # book_set 反向关联一对多字段的Book def __unicode__(self): return self.name class AuthorDetail(models.Model): sex = models.BooleanField(max_length=1, choices=((0, '男'),(1, '女'),)) author = models.OneToOneField(Author) # author_id隐藏字段,正向关联一对一字段的Author对象的id class Book(models.Model): title = models.CharField(max_length=100) authors = models.ManyToManyField(Author) publisher = models.ForeignKey(Publisher,null=True) # publisher_id隐藏字段,正向关联一对多字段的Publisher对象的id price=models.DecimalField(max_digits=5,decimal_places=2,default=10) def __unicode__(self): return self.title
#coding:utf-8 from __future__ import unicode_literals from django.db import models class Publisher(models.Model): name = models.CharField(max_length=30, verbose_name="名称") website = models.URLField() def __unicode__(self): return self.name class Author(models.Model): name = models.CharField(max_length=30) def __unicode__(self): return self.name class AuthorDetail(models.Model): sex = models.BooleanField(max_length=1, choices=((0, '男'),(1, '女'),)) author = models.OneToOneField(Author) class Book(models.Model): title = models.CharField(max_length=100) authors = models.ManyToManyField(Author,through='Book2Author') publisher = models.ForeignKey(Publisher) price=models.DecimalField(max_digits=5,decimal_places=2,default=10) def __unicode__(self): return self.title class Book2Author(models.Model): book = models.ForeignKey(Book) author = models.ForeignKey(Author) groupname = models.CharField(max_length=100) #默认多对多关系Django自动为我们创建了一张中间表,仅提供3个字段,两个关联表的外键字段和一个id字段。 #这种使用自定义中间表的方式,使得我们可以自定义的为中间表添加额外的字段。当我们需要为多对多关系提供额外字段时,用此方式。
2、同步数据库
模型表创建和更新的时候是要使用数据库迁移命令,使模型类的改变同步到数据库。
makemigrations #创建变更记录
migrate #同步到数据库
3、Model类(表)关系图:
名词说明:
正向查询,从定义关系字段的类中去查询关系对象的值或值的集合。举个栗子:从AuthorDetail类中查询关联字段author对象的值。
反向查询,从本类中查询被关联对象中的值或值的集合。举个栗子:从Author对象中查询被关联字段AuthorDetail对象的值。
4、字段类型:
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、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 文件