-
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是一个抽象基础类
在一个空数据库和这个 models.py
文件上运行 manage.py syncdb
会创建三张表 Author, Book, SmithBook
而抽象基础类的情况下,只创建了 Author, SmithBook 两张表。
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"
扫一扫 关注微信公众号!号主 专注于搜索和推荐系统,尝试使用算法去更好的服务于用户,包括但不局限于机器学习,深度学习,强化学习,自然语言理解,知识图谱,还不定时分享技术,资料,思考等文章!
【技术服务】,详情点击查看:https://mp.weixin.qq.com/s/PtX9ukKRBmazAWARprGIAg