zoukankan      html  css  js  c++  java
  • Django day03之表设计分析

    
    models.py文件中创建表字段分析实例:
    图书管理系统--->
    书、作者、出版社作为基表
    
    from django.db import models
    
    # Create your models here.
    #先不要考虑外键关系,先创基表
    class Book(models.Model):
        '''
        书名、价格、出版社、作者
        '''
        title=models.CharField(max_length=32)
        #小数长度总共8位,小数占两位
        price=models.DecimalField(max_digits=8,decimal_places=2)
        #出版社和书是一对多关系,并且书是多的一方,所以外键字段建在书表中,
        publish=models.ForeignKey(to='Publish')
        #to用来指代和哪张表有关系,默认关联的就是表的主键字段
        '''
        一对多外键字段在创建的时候,同步到数据中,表字段会自动加_id后缀
        如果你自己加了_id,我ORM头铁,会在后面再加一个_id,
        所以你在写一对多外键字段的时候,不要自作聪明的加_id。
        
        '''
        #一本书可以有多个作者,一个作者可以有多本书,所以书和作者是多对多的关系,
        # 外间字段建在任意一方都可以,但是建议你建立在查询频率较高的一方。
        author=models.ManyToManyField(to='Author')
        #django  orm 会自动帮你创建书籍和作者的第三张关系表,
        #author这个字段是一个虚拟字段,不会再表中展示出来,仅仅只是起到一个
        #告诉 orm 建第三张表的关系的作用。
    
    class Publish(models.Model):
        '''
        出版社名字、出版社邮箱
        '''
        title=models.CharField(max_length=32)
        email=models.EmailField()
    
    class Author(models.Model):
        '''
        作者名字、作者年龄
        '''
        name=models.CharField(max_length=64)
        age=models.IntegerField()
        #作者表和作者详情表是一对一的表关系,外键字段建在任意一方都可以,
        #但是建议你建在查询频率较高的那一方。
        author_detail=models.OneToOneField(to='Author_detail')
        '''
        一对一的外键字段,创建的时候,同步到数据中,表字段会自动加_id后缀,
        如果你自己加了_id  我orm头铁,在后面再加一个_id,
        所以你在写一对一外键字段的时候,不要自作聪明的加_id 。
        '''
    
    
    class Author_detail(models.Model):
        '''
        作者手机号、作者地址
        '''
        phone=models.BigIntegerField()
        addr=models.CharField(max_length=32)
    
    
    
    
    
    
  • 相关阅读:
    ADO.NET_01_概述
    我对持久层的一点看法
    浅谈极限编程(XP)和代码重构(Refectoring)
    设计模式_第一篇_开场
    .NET OracleLob 读写操作
    ASP.NET_ASP.NET Cookies
    设计模式_第二篇_策略模式
    Oracle_C# 实现 Oracle Text(全文检索)的一个简单例子
    IKVM.NET_06_用户指南_教程
    ADO.NET_02_DataTable
  • 原文地址:https://www.cnblogs.com/ludundun/p/11938203.html
Copyright © 2011-2022 走看看