Pycharm開發(fā)Django項目創(chuàng)建ORM模型的問題
隨著項目越來越大,采用寫原生SQL的方式在代碼中會出現大量的SQL語句,那么問題就出現了:
- SQL語句重復利用率不高,越復雜的SQL語句條件越多,代碼越長。會出現很多相近的SQL語句。
- 很多SQL語句是在業(yè)務邏輯中拼出來的,如果有數據庫需要更改,就要去修改這些邏輯,這會很容易漏掉對某些SQL語句的修改。
- 寫SQL時容易忽略web安全問題,給未來造成隱患。SQL注入。
ORM
,全稱Object Relational Mapping
,中文叫做對象關系映射,通過ORM
我們可以通過類的方式去操作數據庫,而不用再寫原生的SQL語句。通過把表映射成類,把行作實例,把字段作為屬性,ORM
在執(zhí)行對象操作的時候最終還是會把對應的操作轉換為數據庫原生語句。使用ORM
有許多優(yōu)點:
- 易用性:使用
ORM
做數據庫的開發(fā)可以有效的減少重復SQL語句的概率,寫出來的模型也更加直觀、清晰。 - 性能損耗小:
ORM
轉換成底層數據庫操作指令確實會有一些開銷。但從實際的情況來看,這種性能損耗很少(不足5%),只要不是對性能有嚴苛的要求,綜合考慮開發(fā)效率、代碼的閱讀性,帶來的好處要遠遠大于性能損耗,而且項目越大作用越明顯。 - 設計靈活:可以輕松的寫出復雜的查詢。
- 可移植性:
Django
封裝了底層的數據庫實現,支持多個關系數據庫引擎,包括流行的MySQL
、PostgreSQL
和SQLite
??梢苑浅]p松的切換數據庫。
創(chuàng)建ORM模型:
ORM
模型一般都是放在app
的models.py
文件中。每個app
都可以擁有自己的模型。并且如果這個模型想要映射到數據庫中,那么這個app
必須要放在settings.py
的INSTALLED_APP
中進行安裝。以下是寫一個簡單的書籍ORM
模型。示例代碼如下:
from django.db import models class Book(models.Model): name = models.CharField(max_length=20,null=False) author = models.CharField(max_length=20,null=False) pub_time = models.DateTimeField(default=datetime.now) price = models.FloatField(default=0)
以上便定義了一個模型。這個模型繼承自django.db.models.Model
,如果這個模型想要映射到數據庫中,就必須繼承自這個類。這個模型以后映射到數據庫中,表名是模型名稱的小寫形式,為book
。在這個表中,有四個字段,一個為name
,這個字段是保存的是書的名稱,是varchar
類型,最長不能超過20個字符,并且不能為空。第二個字段是作者名字類型,同樣也是varchar
類型,長度不能超過20個。第三個是出版時間,數據類型是datetime
類型,默認是保存這本書籍的時間。第五個是這本書的價格,是浮點類型。
還有一個字段我們沒有寫,就是主鍵id
,在django
中,如果一個模型沒有定義主鍵,那么將會自動生成一個自動增長的int
類型的主鍵,并且這個主鍵的名字就叫做id
。
映射模型到數據庫中:
將ORM
模型映射到數據庫中,總結起來就是以下幾步:
- 在
settings.py
中,配置好DATABASES
,做好數據庫相關的配置。 - 在
app
中的models.py
中定義好模型,這個模型必須繼承自django.db.models
。 - 將這個
app
添加到settings.py
的INSTALLED_APP
中。 - 在命令行終端,進入到項目所在的路徑,然后執(zhí)行命令
python manage.py makemigrations
來生成遷移腳本文件。 - 同樣在命令行中,執(zhí)行命令
python manage.py migrate
來將遷移腳本文件映射到數據庫中。
到此這篇關于Pycharm開發(fā)Django項目ORM模型介紹的文章就介紹到這了,更多相關Pycharm開發(fā)Django項目內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用Node.js和Socket.IO擴展Django的實時處理功能
這篇文章主要介紹了使用Node.js和Socket.IO擴展Django的實時處理功能,用異步處理實時功能是相當強大的,文中給出的例子是建立一個實時聊天室,需要的朋友可以參考下2015-04-04Python PyQt5實戰(zhàn)項目之查詢器的實現流程詳解
PyQt5以一套Python模塊的形式來實現功能。它包含了超過620個類,600個方法和函數。它是一個多平臺的工具套件,它可以運行在所有的主流操作系統(tǒng)中,包含Unix,Windows和Mac OS。PyQt5采用雙重許可模式。開發(fā)者可以在GPL和社區(qū)授權之間選擇2021-11-11使用Streamlit和Pandas實現帶有可點擊鏈接的數據表格
這篇文章主要為大家詳細介紹了如何利用?Streamlit?和?Pandas?在?Python?中創(chuàng)建一個帶有可點擊鏈接的數據表格,感興趣的小伙伴可以跟隨小編一起學習一下2023-11-11Python利用networkx畫圖繪制Les?Misérables人物關系
這篇文章主要為大家介紹了Python利用networkx畫圖處理繪制Les?Misérables悲慘世界里的人物關系圖,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05