Django从理论到实战(part25)--数据库操作
學(xué)習(xí)筆記,僅供參考
參考自:Django打造大型企業(yè)官網(wǎng)–Huang Y;
本系列Blog以應(yīng)用為主,理論基礎(chǔ)部分我在后端專欄的Django系列博客已經(jīng)寫(xiě)過(guò)了,如果有些需要補(bǔ)充的知識(shí)點(diǎn),我會(huì)在這個(gè)系列中,盡量詳細(xì)的記錄一下。
數(shù)據(jù)庫(kù)操作
配置數(shù)據(jù)庫(kù)
在settings.py文件中配置數(shù)據(jù)庫(kù):
DATABASES = { # 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), # }'default': {# 數(shù)據(jù)庫(kù)引擎(是mysql還是oracle等)'ENGINE': 'django.db.backends.mysql',# 數(shù)據(jù)庫(kù)的名字'NAME': 'datacup',# 連接mysql數(shù)據(jù)庫(kù)的用戶名'USER': 'root',# 連接mysql數(shù)據(jù)庫(kù)的密碼'PASSWORD': '19970928',# mysql數(shù)據(jù)庫(kù)的主機(jī)地址'HOST': '127.0.0.1',# mysql數(shù)據(jù)庫(kù)的端口號(hào)'PORT': '3306',}, }操作數(shù)據(jù)庫(kù)
在Django中使用原生sql語(yǔ)句操作其實(shí)就是使用Python DB API的接口來(lái)操作,Django將數(shù)據(jù)庫(kù)連接的這一部分封裝好了,我們只要在settings.py中配置好了數(shù)據(jù)庫(kù)連接信息后嗎,直接使用Django封裝好的接口就可以操作了,例如:
# 使用django封裝好的connection對(duì)象,會(huì)自動(dòng)讀取settings.py中數(shù)據(jù)庫(kù)的配置信息 from django.db import connection# 獲取游標(biāo)對(duì)象 cursor = connection.cursor() # 拿到游標(biāo)對(duì)象后執(zhí)行sql語(yǔ)句 cursor.execute("select * from book") # 獲取所有的數(shù)據(jù) rows = cursor.fetchall() # 遍歷查詢到的數(shù)據(jù) for row in rows:print(row)以上的execute以及fetchall方法都是在Python DB API規(guī)范中定義好的,任何使用Python來(lái)操作MySQL的驅(qū)動(dòng)程序都應(yīng)該遵循這個(gè)規(guī)范。
- cursor對(duì)象常用接口
| description | 如果cursor執(zhí)行了查詢的sql代碼,cursor.description`屬性將返回一個(gè)包含元祖的列表 |
| rowcount | 執(zhí)行了sql語(yǔ)句后受影響的行數(shù) |
| close | 關(guān)閉游標(biāo),關(guān)閉游標(biāo)后就不能使用數(shù)據(jù)庫(kù)了,否則會(huì)拋出異常 |
| execute(sql[,parameters]) | 執(zhí)行某個(gè)sql語(yǔ)句,如果在執(zhí)行sql語(yǔ)句的時(shí)候還需要傳遞參數(shù),那么可以傳給parameters參數(shù) |
| fetchone | 在執(zhí)行了查詢操作以后,獲取第一條數(shù)據(jù) |
| fetchmany(size) | 在執(zhí)行查詢操作以后,獲取多條數(shù)據(jù)。具體是多少條要看size參數(shù),默認(rèn)獲取1條 |
| fetchall | 獲取所有滿足sql語(yǔ)句的數(shù)據(jù) |
實(shí)戰(zhàn)
- 創(chuàng)建數(shù)據(jù)表
- 創(chuàng)建視圖函數(shù)
- 創(chuàng)建路由
- 發(fā)起請(qǐng)求
向http://127.0.0.1:8000/bookstore/發(fā)起請(qǐng)求:
查看數(shù)據(jù)庫(kù)中數(shù)據(jù):
mysql> select * from bookstore0708; +----+----------+--------+ | id | bookname | author | +----+----------+--------+ | 1 | 數(shù)值分析 | TS | | 2 | 機(jī)器學(xué)習(xí) | ZZH | | 3 | 機(jī)器學(xué)習(xí) | ZZH | +----+----------+--------+ 3 rows in set (0.01 sec)看來(lái),我不小心發(fā)送了兩次請(qǐng)求。
總結(jié)
以上是生活随笔為你收集整理的Django从理论到实战(part25)--数据库操作的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 对图片进行Base64转码和解码
- 下一篇: Django从理论到实战(part31)