Quantcast
Viewing all articles
Browse latest Browse all 9596

Python之路【第十九章】:Django 数据库对象关系映射

Django ORM基本配置

到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞:

创建数据库,设计表结构和字段 使用 mysqldb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行数据库操作

django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM),django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表

1、修改project数据库配置 (程序主目录下的 settings.py文件)

默认连接数据库为本地文件sqlite3:

DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } }

更换为指定的mysql数据库:

DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME':'zyweb', #数据库名 'USER': 'root', #账号 'PASSWORD': 'zyw@123', #密码 'HOST': '192.168.28.129', #mysql数据库IP 'PORT': '3306', #对端端口 } }

2、创建定义数据库表结构文件 (对应app目录下的models.py文件)

生成一个简单的数据库表:

from django.db import models # Create your models here. class UserInfo(models.Model): # 创建的表名名称为cmdb_userinfo # 数据库默认创建id列 自增 主键 # 用户名列 字符串类型 字符长度 username = models.CharField(max_length=32) passwd = models.CharField(max_length=64)

把对应的app名称加入到settings.py文件配置里:

INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'cmdb', # 系统会加载cmdb下的model.py文件 ]   3、生成数据库表

执行下面命令:

python manage.py makemigrations python manage.py migrate # 生成数据表

查看数据库表详情:

mysql> desc cmdb_userinfo; +----------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | username | varchar(32) | NO | | NULL | | | passwd | varchar(64) | NO | | NULL | | +----------+-------------+------+-----+---------+----------------+ 3 rows in set (0.01 sec)

注意:Django默认用的MysqlDB模块连接数据库,但在python3.x里面还没有这个模块,所有需要把连接数据库的模块改成pymsyql,修改project目录下的init.py文件

import pymysql pymysql.install_as_MySQLdb() 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 文件 所有字段... null -> db是否可以为空 default -> 默认值 primary_key -> 主键 db_column -> 列名 db_index -> 索引 unique -> 唯一索引 unique_for_date -> unique_for_month unique_for_year auto_now -> 创建时,自动生成时间 auto_now_add -> 更新时,自动更新为当前时间 choices -> django admin中显示下拉框,避免连表查询 blank -> django admin是否可以为空 verbose_name -> django admin显示字段中文 editable -> django admin是否可以被编辑 error_messages -> 错误信息欠 help_text -> django admin提示 validators -> django form, 自定义错误信息(欠) 所有字段参数... Django 数据库操作 1、增加数据

第一种方式(最常用):

from cmdb import models def ormadd(request): models.UserInfo.objects.create(username="James",passwd="8888") return HttpResponse("ormadd")

第一种方式的另一种写法:

from cmdb import models def ormadd(request): dicts = {'username':"James",'passwd':"8888"} models.UserInfo.objects.create(**dicts) return HttpResponse("ormadd")

第二种方式:

from cmdb import models def ormadd(request): obj = models.UserInfo(username='root',passwd='123') obj.save() return HttpResponse("ormadd") 2、查询数据

查询所有:

from cmdb import models def ormselect(request): result = models.UserInfo.objects.all() print(result) # QuerySet类型 列表里每个元素都是一个obj对象 # <QuerySet [<UserInfo: UserInfo object>, <UserInfo: UserInfo object>, <UserInfo: UserInfo object>]> for row in result: print(row.id,row.username,row.passwd) # 1 James 8888 # 2 root 123 # 3 James 8888 return HttpResponse("ormselect")

查找指定字段:

from cmdb import models def ormselect(request): result = models.UserInfo.objects.filter(username='root') # filter()里可以用,分开 表示and if result: for row in result: print(row.id,row.username,row.passwd) # 2 root 123 return HttpResponse("ormselect")

获取查询第一条数据和统计匹配个数:

from cmdb import models def ormselect(request): obj = models.UserInfo.objects.filter(username='root').filter() # 获取匹配的第一条字段 c = models.UserInfo.objects.filter(username='root').count() # 获取匹配的字段个数 return HttpResponse("ormselect") 3、删除数据

删除指定字段:

from cmdb import models def ormdel(request): models.UserInfo.objects.filter(id=3).delete() return HttpResponse("ormdel") 4、更新数据

更新指定字段:

from cmdb import models def ormupdate(request): models.UserInfo.objects.filter(id=2).update(passwd='99999') return HttpResponse("ormupdate") 5、单表外键关联

数据库表结构:

from django.db import models # Create your models here. class UserInfo(models.Model): # 创建的表名名称为cmdb_userinfo username = models.CharField(max_length=32) passwd = models.CharField(max_length=64) # 关联外键 生成字段名为user_group_id user_group = models.ForeignKey("UserGroup",to_field='uid',default=1) #关联usergroup表的uid字段默认为1 class UserGroup(models.Model): # 创建的表名名称为cmdb_usergroup uid = models.AutoField(primary_key=True) #主键 自增 caption = models.CharField(max_length=32,unique=True) #唯一索引 ctime = models.DateField(auto_now_add=True,null=True) #创建时生成时间 uptime = models.DateField(auto_now=True,null=True) #更新是自动更新时间

外键关联表操作:

from cmdb import models def ormadd(request): models.UserInfo.objects.create(username="James",passwd="8888") return HttpResponse("ormadd") def ormgroup(request): models.UserGroup.objects.create(caption="CEO") return HttpResponse("ormgroup") def userinfo(request): obj = models.UserInfo.objects.all().first() # user_group_id 指定的是userinfo表里存的id号 print(obj.id,obj.username,obj.user_group_id) # 1 James 1 # user_group 指定的是用户组obj对象 print(obj.user_group.uid,obj.user_group.caption) # 1 CEO return HttpResponse("userinfo")


Viewing all articles
Browse latest Browse all 9596

Trending Articles