<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                # 一、需求 **定義模型類,保存部門-員工數據** * 部門類(Department) * 部門名稱: name * 部門成立時間: create\_date * 邏輯刪除標識:is\_delete * 員工類(Employee) * 性名: name * 年齡: age * 性別: sex * 工資: salary * 入職時間: hire\_date * 備注信息: comment ## 二、模型類定義 * 模型類被定義在`應用/models.py`文件中 * 模型類必須繼承自`Django`的`models.Model`類 #### 1\. 屬性定義 * 模型類屬性與表字段一一對應 * 定義屬性時,需要指定字段類型,通過字段類型的參數指定選項,格式如下: * **屬性名 = models.字段類型(字段選項)** * 屬性名不能是python的保留關鍵字 * 屬性名不能使用連續的下劃線(這是由django的查詢方式決定的) #### 2\. 關于主鍵 * 主鍵:primary key,簡寫 pk * 不需要主動定義,django會自動生成自增長的主鍵,屬性名叫`id`, * 如果開發者自己定義了主鍵,則django不會再生成默認的主鍵 #### 3\. 表名 * 默認為:**應用名小寫\_模型類名小寫** * 可通過通過`Meta`類指定表名,例如 ~~~ # 如果應用名為users,則默認表名為:users_department class Department(models.Model): ... class Meta: # 指定生成的數據庫表的名字 db_table = 'department' ~~~ #### 4\. 字段類型 [官方文檔:字段類型和選項](https://yiyibooks.cn/xx/Django_1.11.6/ref/models/fields.html) | 類型 | 說明 | | --- | --- | | AutoField | 自動增長的IntegerField,通常不用指定,不指定時Django會自動創建名為id的自動增長屬性 | | BooleanField | 布爾字段,值為True或False | | NullBooleanField | 支持Null、True、False三種值 | | CharField | 字符串,**必須指定**:`max_length`,表示最大字符個數 | | TextField | 大文本字段,一般超過4000個字符時使用 | | IntegerField | 整數 | | DecimalField | 十進制浮點數,用python中的Decimal實例來表示 必須指定:`max_digits`總位數,`decimal_places`小數位數。 | | FloatField | 浮點數 | | DateField | 日期 1,參數`auto_now`表示每次修改保存對象時,自動設置該字段為當前時間,用于保存"最后一次修改"時間,默認為False;2, 參數`auto_now_add`表示當對象第一次被創建時自動設置保存當前時間,用于保存"創建時間"時間,默認為值為False; 3, 參數`auto_now_add`和`auto_now`是相互排斥的,不能同時用到一個屬性中 | | TimeField | 時間,參數同DateField | | DateTimeField | 日期時間,參數同DateField | | FileField | 上傳文件字段 | | ImageField | 繼承于FileField,對上傳的內容進行校驗,確保是有效的圖片 | #### 4\. 字段選項 | 選項 | 默認值 | 描述 | 是否要遷移修改表結構 | | --- | --- | --- | --- | | null | False | True表示表字段允許為空 | 是 | | unique | False | True表示表字段不能重復 | 是 | | db\_column | 屬性名稱 | 表字段名稱 | 是 | | primary\_key | False | True表示字段設置為了主鍵,一般作為AutoField的選項使用 | 是 | | default | \- | 默認值 | 否 | | blank | False | 在django管理后臺新增或編輯一條表數據時,該字段是否允許為空;null是數據庫范疇的概念,blank是表單驗證范疇的 | 否 | | choices | \- | 在django管理后臺新增或編輯一條表數據時,該字段顯示為下拉框,默認為編輯框 | 否 | * choices: 性別屬性使用了choices選項后,在錄入一條數據時,會以下拉框顯示 * blank:blank屬性默認值為false, 表示錄入一條數據時,當前字段必須填寫,不能為空,否則js端js校驗不通過,例如:下圖的comment員工備注信息字段。 ![image](../imgs/django-063.png) #### 5\. 外鍵 關系型數據庫的關系包括三種類型 * `ForeignKey`: 一對多,將`關聯屬性`定義在多的一端中 * `ManyToManyField`: 多對多,將`關聯屬性`定義任意一方中 * `OneToOneField`: 一對一,將`關聯屬性`定義在任意一方中 ## 二、代碼參考 部門和員工模型類 代碼參考 ~~~ class Department(models.Model): """部門類""" # 部門名稱:字符串類型(必須要指定最大長度) name = models.CharField(max_length=20) # 部門成立時間: 日期類型 create_date = models.DateField(auto_now_add=True) # 邏輯刪除標識:標識部門是否刪除 is_delete = models.BooleanField(default=False) def __str__(self): return self.name class Meta: # 指定表名 db_table = 'department' class Employee(models.Model): """員工類""" choices_gender = ( (0, '男'), (1, '女'), ) name = models.CharField(max_length=20) age = models.IntegerField() gender = models.IntegerField(default=0, choices=choices_gender) # 工資:浮點類型(必須要指定兩個選項) 999999.99 salary = models.DecimalField(max_digits=8, decimal_places=2) # 備注信息: 可以為空 comment = models.CharField(max_length=300, null=True, blank=True) # 員工入職時間 hire_date = models.DateField(auto_now_add=True) # 一對多的外鍵:員工所屬部門 department_id department = models.ForeignKey('Department') def __str__(self): return self.name class Meta: # 指定表名 db_table = 'employee' ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看