# 一、需求
**定義模型類,保存部門-員工數據**
* 部門類(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員工備注信息字段。

#### 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'
~~~
- 基礎
- 輸入輸出
- 常量變量
- 常量
- 變量
- 數據類型
- 簡單數據類型
- 整型
- 浮點型
- 復數
- 復雜數據類型
- 序列
- 通用操作
- 字符串
- 定義
- 方法
- 格式化
- eval
- range
- capitalize
- count
- 格式化
- list
- 定義
- 方法
- tuple
- 定義
- 特點
- 方法
- dict
- 定義
- set
- 定義
- 類型轉換
- 函數
- 定義
- 參數
- 函數變量
- 多返回值
- 作用域
- 函數嵌套
- 匿名函數
- 面向對象
- 類
- 對象
- 封裝
- 私有
- property
- 類屬性和實例屬性
- 實例方法、靜態方法和類方法
- 繼承
- 多態
- 接口
- 設計原則
- 開放/封閉原則
- 控制反轉原則
- 接口隔離原則
- 單一職責原則
- 替換原則
- 魔法方法
- 構造方法
- 析構方法
- 靜態方法
- doc
- call
- dict
- str
- 異常
- with
- 提高
- 深淺拷貝
- 閉包
- 裝飾器
- 正則表達式
- 單個字符
- 多個字符
- 開頭結尾
- 分組
- 高級語法
- 網絡編程
- 多任務
- 線程
- 創建線程
- 主線程等待
- 共享全局變量
- 傳遞參數
- 進程
- 創建
- 進程間通信
- 協程
- 數據庫
- SQL
- 安裝
- 備份
- 查詢
- 消除重復行
- 分組
- 字查詢
- Python 中操作 MySQL
- 設計模式
- 簡介
- 三大類
- 創建型
- 單例
- 常用模塊
- 導入模塊
- 系統內置
- os
- time
- math
- help
- logging
- 格式
- 輸出到控制臺
- 輸出到文件
- 兩個都輸出
- 三方模塊
- Tesseract
- redis
- 安裝
- selenium
- Selenium
- PhantomJS
- Chromedriver
- turtle
- 五角星
- 正方體
- urllib3
- http請求
- Requests
- 基本使用
- 發送請求
- cookies
- 代理
- Django
- 框架介紹
- 項目搭建
- 項目配置
- 路由
- 項目urls.py
- 應用urls.py
- 控制器
- request
- response
- Cookie
- Session
- views
- Models
- 數據庫
- ORM
- 配置和遷移
- 模型類
- 模型管理器
- 增刪改
- 查
- 查詢集
- Mysql日志
- 自定義模型管理器
- 中間件
- scrapy
- 工作原理
- 創建項目
- spider
- items
- pipeline
- settings
- logging
- 小例子
- 果殼網
- 人人網登陸
- 騰訊招聘
- 創建模塊
- 網絡爬蟲
- 基礎知識
- 爬蟲的用途
- robots協議
- http和https
- 常見請求頭
- 狀態碼
- 字符串
- requests
- 簡介
- 發送請求
- response
- 小技巧
- 代理
- cookie和session
- Fiddler
- 數據提取
- 數據分類
- json
- 正則
- xpath
- lxml
- 自動化運維
- Shell
- 開發規范
- 注釋
- 腳本執行
- 變量
- 表達式
- 測試語句
- 條件表達式
- 邏輯表達式
- 文件表達式
- 數值操作符
- 字符串比較
- 計算表達式
- 常見符號
- 重定向符號
- 管道符
- 其他符號
- 常見命令
- grep
- sed
- awk
- find
- 流程控制
- if