SQLite是一種嵌入式數(shù)據(jù)庫(kù)俱诸,它的數(shù)據(jù)庫(kù)就是一個(gè)文件菠劝。由于SQLite本身是C寫的,而且體積很小乙埃,所以,經(jīng)常被集成到各種應(yīng)用程序中锯岖,甚至在iOS和Android的App中都可以集成介袜。
Python就內(nèi)置了SQLite3,所以出吹,在Python中使用SQLite遇伞,不需要安裝任何東西,直接使用捶牢。
在使用SQLite前鸠珠,我們先要搞清楚幾個(gè)概念:
表是數(shù)據(jù)庫(kù)中存放關(guān)系數(shù)據(jù)的集合,一個(gè)數(shù)據(jù)庫(kù)里面通常都包含多個(gè)表秋麸,比如學(xué)生的表渐排,班級(jí)的表,學(xué)校的表灸蟆,等等僧须。表和表之間通過(guò)外鍵關(guān)聯(lián)懊蒸。
要操作關(guān)系數(shù)據(jù)庫(kù),首先需要連接到數(shù)據(jù)庫(kù),一個(gè)數(shù)據(jù)庫(kù)連接稱為Connection展哭;
連接到數(shù)據(jù)庫(kù)后,需要打開(kāi)游標(biāo)汁讼,稱之為Cursor玄货,通過(guò)Cursor執(zhí)行SQL語(yǔ)句,然后瓤帚,獲得執(zhí)行結(jié)果描姚。
Python定義了一套操作數(shù)據(jù)庫(kù)的API接口,任何數(shù)據(jù)庫(kù)要連接到Python戈次,只需要提供符合Python標(biāo)準(zhǔn)的數(shù)據(jù)庫(kù)驅(qū)動(dòng)即可轰胁。
由于SQLite的驅(qū)動(dòng)內(nèi)置在Python標(biāo)準(zhǔn)庫(kù)中,所以我們可以直接來(lái)操作SQLite數(shù)據(jù)庫(kù)朝扼。
我們?cè)赑ython交互式命令行實(shí)踐一下:
# 導(dǎo)入SQLite驅(qū)動(dòng):
>>> import sqlite3
# 連接到SQLite數(shù)據(jù)庫(kù)
# 數(shù)據(jù)庫(kù)文件是test.db
# 如果文件不存在赃阀,會(huì)自動(dòng)在當(dāng)前目錄創(chuàng)建:
>>> conn = sqlite3.connect('test.db')
# 創(chuàng)建一個(gè)Cursor:
>>> cursor = conn.cursor()
# 執(zhí)行一條SQL語(yǔ)句,創(chuàng)建user表:
>>> cursor.execute('create table user (id varchar(20) primary key, name varchar(20))')
<sqlite3.Cursor object at 0x10f8aa260>
# 繼續(xù)執(zhí)行一條SQL語(yǔ)句,插入一條記錄:
>>> cursor.execute('insert into user (id, name) values (\'1\', \'Michael\')')
<sqlite3.Cursor object at 0x10f8aa260>
# 通過(guò)rowcount獲得插入的行數(shù):
>>> cursor.rowcount
1
# 關(guān)閉Cursor:
>>> cursor.close()
# 提交事務(wù):
>>> conn.commit()
# 關(guān)閉Connection:
>>> conn.close()
我們?cè)僭囋嚥樵冇涗洠?/p>
>>> conn = sqlite3.connect('test.db')
>>> cursor = conn.cursor()
# 執(zhí)行查詢語(yǔ)句:
>>> cursor.execute('select * from user where id=?', ('1',))
<sqlite3.Cursor object at 0x10f8aa340>
# 獲得查詢結(jié)果集:
>>> values = cursor.fetchall()
>>> values
[('1', 'Michael')]
>>> cursor.close()
>>> conn.close()```
使用Python的DB-API時(shí)榛斯,只要搞清楚Connection和Cursor對(duì)象观游,打開(kāi)后一定記得關(guān)閉,就可以放心地使用驮俗。
使用Cursor對(duì)象執(zhí)行insert懂缕,update,delete語(yǔ)句時(shí)王凑,執(zhí)行結(jié)果由rowcount返回影響的行數(shù)搪柑,就可以拿到執(zhí)行結(jié)果。
使用Cursor對(duì)象執(zhí)行select語(yǔ)句時(shí)索烹,通過(guò)featchall()可以拿到結(jié)果集工碾。結(jié)果集是一個(gè)list,每個(gè)元素都是一個(gè)tuple百姓,對(duì)應(yīng)一行記錄渊额。
如果SQL語(yǔ)句帶有參數(shù),那么需要把參數(shù)按照位置傳遞給execute()方法垒拢,有幾個(gè)?占位符就必須對(duì)應(yīng)幾個(gè)參數(shù)旬迹,例如:
`cursor.execute('select * from user where name=? and pwd=?', ('abc', 'password'))`
SQLite支持常見(jiàn)的標(biāo)準(zhǔn)SQL語(yǔ)句以及幾種常見(jiàn)的數(shù)據(jù)類型。具體文檔請(qǐng)參閱SQLite官方網(wǎng)站求类。