Django框架入門 -- (四)數據模型及數據庫的操作
1.根據表字段定義類
【案例】假設有兩張表:person表和order表,字段分別如下。
person表中有四個字段:first_name(字符串),last_name(字符串),created_at(日期類型),updated_at(日期類型)。
order表中有四個字段:order_id(FK),order_desc(字符串),created_at,updated_at。
則在models.py內編寫的代碼如下:
from django.db import models
# 模型類需要繼承一個父類
class Person(models.Model):
# 表中有四個字段:first_name(字符串),last_name(字符串),created_at(日期類型),updated_at
# 需要在Person類中生成這四個字段
first_name = models.CharField(max_length=30)
last_name = models.CharField(max_length=30)
created_at = models.DateField(auto_now_add=True)
updated_at = models.DateField(auto_now=True)
class Order(models.Model):
# order_id(FK),order_desc(訂單描述),created_at,updated_at
order_id = models.CharField(max_length=30, db_index=True)
order_desc = models.CharField(max_length=100)
created_at = models.DateField(auto_now_add=True)
updated_at = models.DateField(auto_now=True)
其中created_at,updated_at是兩張表都有的字段,可以提取到一個類中。
from django.db import models
# 相同字段可以提取一個類,沒有對應數據庫中的某張表
class CreateUpdate(models.Model):
created_at = models.DateField(auto_now_add=True)
updated_at = models.DateField(auto_now=True)
# 這樣生成數據庫時候就不會生成此表
class Meta:
abstract = True
# 模型類需要繼承一個父類
class Person(CreateUpdate):
# 表中有四個字段:first_name(字符串),last_name(字符串),created_at(日期類型),updated_at
# 需要在Person類中生成這四個字段
first_name = models.CharField(max_length=30)
last_name = models.CharField(max_length=30)
class Order(CreateUpdate):
# order_id(FK),order_desc(訂單描述),created_at,updated_at
order_id = models.CharField(max_length=30, db_index=True)
order_desc = models.CharField(max_length=100)
2.配置連接mysql數據庫
打開demo下的settings.py文件,對數據庫配置部分進行修改:
修改內容:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'db_django_demo', # 數據庫名
'USER': 'root',
'PASSWORD': '123456'
}
}
3.連接mysql數據庫
(1)打開數據庫圖形化工具,新建一個數據庫,名稱為:db_django_demo。
(2)安裝mysql數據庫驅動(sqlite不需要安裝):
(base) E:\workspace\pycharm\django\start_demo\demo>pip install pymysql
(3)引入mysql驅動模塊:
import pymysql
pymysql.install_as_MySQLdb()
(4)將models.py中的數據模型轉換為數據表:
(base) E:\workspace\pycharm\django\start_demo\demo>python manage.py makemigrations
(5)遷移數據,生成數據表:
(base) E:\workspace\pycharm\django\start_demo\demo>python manage.py migrate
此時兩張表已生成:
查看數據表:
4.插入數據
(base) E:\workspace\pycharm\django\start_demo\demo>python manage.py shell
進入python交互的命令行:
編寫以下python代碼:
(base) E:\workspace\pycharm\django\start_demo\demo>python manage.py shell
Python 3.7.4 (default, Aug 9 2019, 18:34:13) [MSC v.1915 64 bit (AMD64)]
Type 'copyright', 'credits' or 'license' for more information
IPython 7.8.0 -- An enhanced Interactive Python. Type '?' for help.
In [1]: from app1.models import Person,Order
In [2]: Person.objects.create(first_name="Li",last_name="lei")
Out[2]: <Person: Person object (1)>
此時查看數據表,數據已插入:
智能推薦
Django入門(四) 簡單操作數據庫
經過前面三節的練習,我們已經可以將一個頁面動態的展現給用戶了。但是真正動態語言還需要連接數據庫,將數據庫中的內容讀取出來呈現在給客戶。這一節我們就來實現簡單的讀寫數據庫,對數據庫進行增刪改查等操作。 前面我們講過django有一個全局的配置文件settings.py,這個文件位于子目錄myjango下面...
四.驅動框架入門之LED(中)
接上篇:https://blog.csdn.net/wangweijundeqq/article/details/101696862 目錄 五.基于驅動框架寫led驅動1 5.1、分析 5.2、動手寫led驅動模塊 六.基于驅動框架寫led驅動2 6.1、代碼實踐 七.基于驅動框架寫led驅動3 7.1、在驅動中將4個LED分開 7.2、和leds-s3c24xx.c的不同 7.3、gpiolib...
React框架入門學習(四)-----個人博客搭建
采用 Semantic-UI ,鏈接是: https://react.semantic-ui.com/ 下面介紹使用方法,Semantic-UI團隊已經做好了許多React組件,我們只需要根據官方網頁中的提示引入React組件就可以使用。在使用之前,先要在我們本地的React項目里安裝Semantic-...
SpringBoot框架入門(四、dubbo常用屬性介紹)
在dubbo中我們會看到許多標簽屬性,如常見的timeout,version,group,這些屬性都有自己代表的意義,這次屬性的不同配置也會對我們的項目產生不同的影響。 幾種配置的介紹 配置名稱 配置應用 RegistryConfig 注冊中心配置,用于配置連接注冊中心相關信息 ProtocolConfig 協議配置,用于配置提供服務的協議信息 ApplicationConfig 用于配置當前應用...
猜你喜歡
freemarker + ItextRender 根據模板生成PDF文件
1. 制作模板 2. 獲取模板,并將所獲取的數據加載生成html文件 2. 生成PDF文件 其中由兩個地方需要注意,都是關于獲取文件路徑的問題,由于項目部署的時候是打包成jar包形式,所以在開發過程中時直接安照傳統的獲取方法沒有一點文件,但是當打包后部署,總是出錯。于是參考網上文章,先將文件讀出來到項目的臨時目錄下,然后再按正常方式加載該臨時文件; 還有一個問題至今沒有解決,就是關于生成PDF文件...
電腦空間不夠了?教你一個小秒招快速清理 Docker 占用的磁盤空間!
Docker 很占用空間,每當我們運行容器、拉取鏡像、部署應用、構建自己的鏡像時,我們的磁盤空間會被大量占用。 如果你也被這個問題所困擾,咱們就一起看一下 Docker 是如何使用磁盤空間的,以及如何回收。 docker 占用的空間可以通過下面的命令查看: TYPE 列出了docker 使用磁盤的 4 種類型: Images:所有鏡像占用的空間,包括拉取下來的鏡像,和本地構建的。 Con...
requests實現全自動PPT模板
http://www.1ppt.com/moban/ 可以免費的下載PPT模板,當然如果要人工一個個下,還是挺麻煩的,我們可以利用requests輕松下載 訪問這個主頁,我們可以看到下面的樣式 點每一個PPT模板的圖片,我們可以進入到詳細的信息頁面,翻到下面,我們可以看到對應的下載地址 點擊這個下載的按鈕,我們便可以下載對應的PPT壓縮包 那我們就開始做吧 首先,查看網頁的源代碼,我們可以看到每一...
Linux C系統編程-線程互斥鎖(四)
互斥鎖 互斥鎖也是屬于線程之間處理同步互斥方式,有上鎖/解鎖兩種狀態。 互斥鎖函數接口 1)初始化互斥鎖 pthread_mutex_init() man 3 pthread_mutex_init (找不到的情況下首先 sudo apt-get install glibc-doc sudo apt-get install manpages-posix-dev) 動態初始化 int pthread_...