03.Django的MTV开发模式详解和模型关系构建

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"

搜索与推荐Wiki

扫一扫 关注微信公众号!号主 专注于搜索和推荐系统,尝试使用算法去更好的服务于用户,包括但不局限于机器学习,深度学习,强化学习,自然语言理解,知识图谱,还不定时分享技术,资料,思考等文章!


                             【技术服务】,详情点击查看:https://mp.weixin.qq.com/s/PtX9ukKRBmazAWARprGIAg 


外包服务

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值