2 Model層
阿新 • • 發佈:2018-01-13
mar 文件的 表單驗證 book 浮點 use script virt 自動
1 ORM簡介
- MVC框架中包括一個重要的部分,就是ORM,它實現了數據模型與數據庫的解耦,即數據模型的設計不需要依賴於特定的數據庫,通過簡單的配置就可以輕松更換數據庫
- ORM是“對象-關系-映射”的簡稱,主要任務是:
- 根據對象的類型生成表結構
- 將對象、列表的操作,轉換為sql語句
- 將sql查詢到的結果轉換為對象、列表
- 這極大的減輕了開發人員的工作量,不需要面對因數據庫變更而導致的無效勞動
- Django中的模型包含存儲數據的字段和約束,對應著數據庫中唯一的表
2 使用mysql 數據庫
- 在虛擬環境中安裝mysql包
python@ubuntu:~$ workon h4 (h4) python@ubuntu:~$ pip list (h4) python@ubuntu:~$ pip install mysql-python
(h4) python@ubuntu:~/Desktop/projects$ django-admin startproject test2
- 在mysql中創建數據庫
python@ubuntu:~$ mysql -uroot -pmysql
create databases test2 charset=utf8
- 打開settings.py文件,修改DATABASES項
DATABASES = { ‘default‘: { ‘ENGINE‘: ‘django.db.backends.mysql‘, ‘NAME‘: ‘test2‘, ‘USER‘: ‘用戶名‘, ‘PASSWORD‘: ‘密碼‘, ‘HOST‘: ‘數據庫服務器ip,本地可以使用localhost‘, ‘PORT‘: ‘端口,默認為3306‘, } }
- 源代碼 django.db.backends.mysql
python@ubuntu:~$ cd .virtualenvs/ python@ubuntu:~/.virtualenvs$ cd h4/ python@ubuntu:~/.virtualenvs/h4$ cd lib/ python@ubuntu:~/.virtualenvs/h4/lib$ cd python2.7/ python@ubuntu:~/.virtualenvs/h4/lib/python2.7$ cd site-packages/ python@ubuntu:~/.virtualenvs/h4/lib/python2.7/site-packages$ ls django pip Django-1.8.2.dist-info pip-9.0.1.dist-info MySQLdb setuptools python@ubuntu:~/.virtualenvs/h4/lib/python2.7/site-packages$ cd django/ python@ubuntu:~/.virtualenvs/h4/lib/python2.7/site-packages/django$ ls apps contrib dispatch __init__.py shortcuts.py templatetags views bin core forms __init__.pyc shortcuts.pyc test conf db http middleware template utils
python@ubuntu:~/.virtualenvs/h4/lib/python2.7/site-packages/django$ cd db/ python@ubuntu:~/.virtualenvs/h4/lib/python2.7/site-packages/django/db$ ls backends __init__.pyc models transaction.pyc utils.pyc __init__.py migrations transaction.py utils.py
python@ubuntu:~/.virtualenvs/h4/lib/python2.7/site-packages/django/db$ cd backends/ python@ubuntu:~/.virtualenvs/h4/lib/python2.7/site-packages/django/db/backends$ ls base __init__.pyc postgresql_psycopg2 sqlite3 utils.py dummy mysql signals.py util.py utils.pyc __init__.py oracle signals.pyc util.pyc
3. 開發流程
- 在models.py中定義模型類,要求繼承自models.Model
- 把應用加入settings.py文件的installed_app項
- 生成遷移文件
- 執行遷移生成表
- 使用模型類進行crud操作
4.使用數據庫生成模型類
python manage.py inspectdb > booktest/models.py
(h4) python@ubuntu:~/Desktop/projects/test2$ python manage.py startapp boostest
5.定義模型
- 在模型中定義屬性,會生成表中的字段
- django根據屬性的類型確定以下信息:
- 當前選擇的數據庫支持字段的類型
- 渲染管理表單時使用的默認html控件
- 在管理站點最低限度的驗證
- django會為表增加自動增長的主鍵列,每個模型只能有一個主鍵列,如果使用選項設置某屬性為主鍵列後,則django不會再生成默認的主鍵列
- 屬性命名限制
- 不能是python的保留關鍵字
- 由於django的查詢方式,不允許使用連續的下劃線
6.字段類型
- AutoField:一個根據實際ID自動增長的IntegerField,通常不指定
- 如果不指定,一個主鍵字段將自動添加到模型中
- BooleanField:true/false 字段,此字段的默認表單控制是CheckboxInput
- NullBooleanField:支持null、true、false三種值
- CharField(max_length=字符長度):字符串,默認的表單樣式是 TextInput
- TextField:大文本字段,一般超過4000使用,默認的表單控件是Textarea
- IntegerField:整數
- DecimalField(max_digits=None, decimal_places=None):使用python的Decimal實例表示的十進制浮點數
- DecimalField.max_digits:位數總數
- DecimalField.decimal_places:小數點後的數字位數
- FloatField:用Python的float實例來表示的浮點數
- DateField[auto_now=False, auto_now_add=False]):使用Python的datetime.date實例表示的日期
- 參數DateField.auto_now:每次保存對象時,自動設置該字段為當前時間,用於"最後一次修改"的時間戳,它總是使用當前日期,默認為false
- 參數DateField.auto_now_add:當對象第一次被創建時自動設置當前時間,用於創建的時間戳,它總是使用當前日期,默認為false
- 該字段默認對應的表單控件是一個TextInput. 在管理員站點添加了一個JavaScript寫的日歷控件,和一個“Today"的快捷按鈕,包含了一個額外的invalid_date錯誤消息鍵
- auto_now_add, auto_now, and default 這些設置是相互排斥的,他們之間的任何組合將會發生錯誤的結果
- TimeField:使用Python的datetime.time實例表示的時間,參數同DateField
- DateTimeField:使用Python的datetime.datetime實例表示的日期和時間,參數同DateField
- FileField:一個上傳文件的字段
- ImageField:繼承了FileField的所有屬性和方法,但對上傳的對象進行校驗,確保它是個有效的image
7.字段選項
- 通過字段選項,可以實現對字段的約束
- 在字段對象時通過關鍵字參數指定
- null:如果為True,Django 將空值以NULL 存儲到數據庫中,默認值是 False
- blank:如果為True,則該字段允許為空白,默認值是 False
- 對比:null是數據庫範疇的概念,blank是表單驗證證範疇的
- db_column:字段的名稱,如果未指定,則使用屬性的名稱
- db_index:若值為 True, 則在表中會為此字段創建索引
- default:默認值
- primary_key:若為 True, 則該字段會成為模型的主鍵字段
- unique:如果為 True, 這個字段在表中必須有唯一值
8.關系
- 關系的類型包括
- ForeignKey:一對多,將字段定義在多的端中
- ManyToManyField:多對多,將字段定義在兩端中
- OneToOneField:一對一,將字段定義在任意一端中
- 可以維護遞歸的關聯關系,使用‘self‘指定,詳見“自關聯”
- 用一訪問多:對象.模型類小寫_set
bookinfo.heroinfo_set
- 用一訪問一:對象.模型類小寫
heroinfo.bookinfo
- 訪問id:對象.屬性_id
heroinfo.book_id
4
5
6
7
8
9
2 Model層