ORM:对象关系映射
一:MTV开发模式
把数据存取逻辑、业务逻辑和表现逻辑组合在一起的概念有时被称为软件架构的
Model-View-Controller
(MVC)模式。 在这个模式中,
Model 代表数据存取层
,
View 代表的是系统中选择显示什么和怎么显示的部分
,
Controller 指的是系统中根据用户输入并视需要访问模型,以决定使用哪个视图的那部分
。
Django也遵循这种MVC开发模式,只不过更名为MTV,下边是django所对应的MVC
-
M ,数据存取部分,由django数据库层处理,本章要讲述的内容。
-
V ,选择显示哪些数据要显示以及怎样显示的部分,由视图和模板处理。
3 -
C ,根据用户输入委派视图的部分,由 Django 框架根据 URLconf 设置,对给定 URL 调用适当的 Python 函数。
由于 C 由框架自行处理,而 Django 里更关注的是模型(Model)、模板(Template)和视图(Views),Django 也被称为 MTV 框架 。在 MTV 开发模式中:
-
M 代表模型(Model),即数据存取层。 该层处理与数据相关的所有事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等。
-
T 代表模板(Template),即表现层。 该层处理与表现相关的决定: 如何在页面或其他类型文档中进行显示。
-
V 代表视图(View),即业务逻辑层。 该层包含存取模型及调取恰当模板的相关逻辑。 你可以把它看作模型与模板之间的桥梁。
二:一对多的模型构建
定义:注意先后顺序
(一个作者对应多本书)
class User(models.Model):
username = models.CharField(max_length=20)
password = models.CharField(max_length=20)
def __unicode__(self): #定义表内容显示的标题
return self.username
class Meta: #自定义数据表名称
db_table = "User"
class Blog (models.Model):
#verbose_name='' : 表示后台中显示的对应名称
title = models.CharField( max_length = 20 , verbose_name = '标题' ) #文章标题
author = models.ForeignKey(User,related_name="blog_author") #外键
#author = models.CharField(max_length=15,verbose_name='作者') #作者
time = models.TimeField( verbose_name = '发表时间' ) #时间
tag = models.CharField( blank = True , max_length = 100 , verbose_name = '文章标签' ) #文章标签 blank=True表示该空格可选填
content = models.TextField( verbose_name = '内容' ) #内容
def __unicode__ ( self ): #后台中显示的标题
return self .title
class Meta : #自定义数据表名字
db_table = "Blog"
三:多对多的模型构建
注意先后顺序
(一个作者可以编写多种类别的文章,一个类别的文章可以被多个作者编写)
class Author(models.Model):
name = models.CharField(max_length=15)
class Blog(models.Model):
#verbose_name='' : 表示后台中显示的对应名称
title = models.CharField(max_length=20, verbose_name='标题') #文章标题
authors = models.ManyToManyField(Author,verbose_name="作者") #外键
#author = models.CharField(max_length=15,verbose_name='作者') #作者
time = models.TimeField(verbose_name='发表时间') #时间
tag = models.CharField(blank=True,max_length=100,verbose_name='文章标签') #文章标签 blank=True表示该空格可选填
content = models.TextField(verbose_name='内容') #内容
def __unicode__(self): #后台中显示的标题
return self.title
class Meta: #自定义数据表名字
db_table = "Blog"
class Category(models.Model):
category = models.CharField(max_length=20,verbose_name='类别')
blog = models.ForeignKey(Blog,related_name="category_blog") #类别
author = models.ForeignKey(User,related_name="category_author") #外键
def __unicode__(self):
return self.category
class Meta:
db_table = "Category"
四:添加模块的字符串表现
class Author(models.Model):
name = models.CharField(max_length=15)
插入和更新数据
a = Author(name='aaa')
a.save()
选择对象
Author.objects.all()
数据过滤
Author.objects.filter(name='Apress',age=12) #以字典形式传值
获取单个对象
Author.objects.get(name='Apress')
这样,就返回了单个对象,而不是列表(更准确的说,QuerySet)。 所以,如果结果是多个对象,会导致抛出异常
如果查询没有返回结果也会抛出异常
数据排序
Author.order_by("name")
连锁查询
Author.objects.filter(name="sss").order_by("-name")
限制返回的数据
Author.order_by("name")[0]
更新多个对象
Author.objects.filter(id=52).update(name='Apress Publishing')
删除对象
Author.objects.filter(name="sss").delete()
class Book(models.Model):这里代码的关键是
title = models.CharField(max_length=100)
genre = models.CharField(max_length=100)
num_pages = models.IntergerField()
authors = models.ManyToManyField(Author)
def __unicode__(self):
return self.title
class Meta:
abstract = True
class SmithBook(Book):
authors = models.ManyToManyField(Author, limit_choices_to = {
'name_endswith': 'Smith'
})
abstract = True
设置, 指明了Book是一个抽象基础类
没有了Meta abstract 选项,
在一个空数据库和这个 models.py
文件上运行 manage.py syncdb
会创建三张表 Author, Book, SmithBook
而抽象基础类的情况下,只创建了 Author, SmithBook 两张表。
六:Meta嵌套类
Meta类处理的是模型的各种元数据的使用和显示:
- 比如在一个对象对多个对象是,它的名字应该怎么显示;
- 查询数据表示默认的排序顺序是什么?
- 数据表的名字是什么
- 多变量唯一性 (这种限制没有办法在每个单独的变量声明上定义)
class Person(models.Model):
first = models.CharField(max_length=100)
last = models.CharField(max_length=100)
middle = models.CharField(max_length=100, blank=True)
class Meta:
ordering = ['last', 'first', 'middle']
unique_together = ['first', 'last', 'middle']
#Django默认的复数形式是加 s,这里不适用
verbose_name_plural = "people"