您的位置:首页 > 编程语言 > Go语言

Django入门-5:模型的基本使用1-模型定义

2017-09-14 08:39 399 查看
    Django模型是与数据库相关的,与数据库相关的代码一般写在 models.py 中,Django支持sqlite3,MySQL,PostgreSQL等数据库,只需要在settings.py中配置即可,不用更改models.py中的代码,丰富的API极大的方便了使用。

ORM简介

MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,
通过简单的配置就可以轻松更换数据库
ORM是“对象-关系-映射”的简称,主要任务是:
根据对象的类型生成表结构
将对象、列表的操作,转换为sql语句
将sql查询到的结果转换为对象、列表
这极大的减轻了开发人员的工作量,不需要面对因数据库变更而导致的无效劳动
Django中的模型包含存储数据的字段和约束,对应着数据库中唯一的表

使用MySql数据库

在虚拟环境中安装mysql包
pipinstallmysql-python
在mysql中创建数据库
createdatabasestest2charset=utf8
打开settings.py文件,修改DATABASES项
DATABASES={
'default':{
'ENGINE':'django.db.backends.mysql',
'NAME':'test2',
'USER':'用户名',
'PASSWORD':'密码',
'HOST':'数据库服务器ip,本地可以使用localhost',
'PORT':'端口,默认为3306',
}
}

开发流程

在models.py中定义模型类,要求继承自models.Model
把应用加入settings.py文件的installed_app项
生成迁移文件
执行迁移生成表
使用模型类进行crud操作

使用数据库生成模型类

pythonmanage.pyinspectdb>booktest/models.py

定义模型

在模型中定义属性,会生成表中的字段
django根据属性的类型确定以下信息:
当前选择的数据库支持字段的类型
渲染管理表单时使用的默认html控件
在管理站点最低限度的验证
django会为表增加自动增长的主键列,每个模型只能有一个主键列,
如果使用选项设置某属性为主键列后,则django不会再生成默认的主键列

属性命名限制

不能是python的保留关键字
name是合法的,student_name也合法,
但是student__name不合法,try,class,continue也不合法,
因为它是Python的关键字(importkeyword;print(keyword.kwlist)可以打出所有的关键字)
由于django的查询方式,不允许使用连续的下划线
字段中不能有__(双下划线,
因为在DjangoQuerySetAPI中有特殊含义
(用于关系,包含,不区分大小写,以什么开头或结尾,日期的大于小于,正则等)
示例:
fromdjango.dbimportmodels
classPerson(models.Model):
name=models.CharField(max_length=30)
age=models.IntegerField()
def__unicode__(self):
#在Python3中使用def__str__(self):
returnself.name
新建一个对象的方法有以下几种:
Person.objects.create(name=name,age=age)
p=Person(name="WZ",age=23)
p.save()
p=Person(name="TWZ")
p.age=23
p.save()
Person.objects.get_or_create(name="WZT",age=23)
这种方法是防止重复很好的方法,但是速度要相对慢些,返回一个元组,第一个为Person对象,第二个为True或False,
新建时返回的是True,已经存在时返回False.
获取对象有以下方法:
Person.objects.all()
Person.objects.all()[:10]切片操作,获取10个人,不支持负索引,切片可以节约内存
Person.objects.get(name=name)
get是用来获取一个对象的,如果需要获取满足条件的一些人,就要用到filter
Person.objects.filter(name="abc")#等于Person.objects.filter(name__exact="abc")名称严格等于"abc"的人
Person.objects.filter(name__iexact="abc")#名称为abc但是不区分大小写,可以找到ABC,Abc,aBC,这些都符合条件
Person.objects.filter(name__contains="abc")#名称中包含"abc"的人
Person.objects.filter(name__icontains="abc")#名称中包含"abc",且abc不区分大小写
Person.objects.filter(name__regex="^abc")#正则表达式查询
Person.objects.filter(name__iregex="^abc")#正则表达式不区分大小写
filter是找出满足条件的,当然也有排除符合某条件的
Person.objects.exclude(name__contains="WZ")#排除包含WZ的Person对象
Person.objects.filter(name__contains="abc").exclude(age=23)#找出名称含有abc,但是排除年龄是23岁的
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: