• 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,这里不适用

    ---------------------
    作者:Thinkgamer_gyt
    来源:CSDN
    原文:https://blog.csdn.net/gamer_gyt/article/details/50167843
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    Java程序设计作业02
    Java程序设计作业01
    DS博客作业05
    DS博客作业04
    DS博客作业03
    DS博客作业02
    DS博客作业01
    C博客作业06
    C博客作业05
    C语言——数组作业批改
  • 原文地址:https://www.cnblogs.com/tsgxj/p/9854332.html
Copyright © 2020-2023  润新知