Python中SQLite如何使用
SQLite是一種嵌入式數(shù)據(jù)庫(kù),它的數(shù)據(jù)庫(kù)就是一個(gè)文件。由于SQLite本身是C寫(xiě)的,而且體積很小,所以,經(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ù)連接稱(chēng)為Connection;
連接到數(shù)據(jù)庫(kù)后,需要打開(kāi)游標(biāo),稱(chēng)之為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\')')
# 通過(guò)rowcount獲得插入的行數(shù):
>>> cursor.rowcount
1
# 關(guān)閉Cursor:
>>> cursor.close()
# 提交事務(wù):
>>> conn.commit()
# 關(guān)閉Connection:
>>> conn.close()
</sqlite3.cursor></sqlite3.cursor>
我們?cè)僭囋嚥樵?xún)記錄:
>>> conn = sqlite3.connect('test.db')
>>> cursor = conn.cursor()
# 執(zhí)行查詢(xún)語(yǔ)句:
>>> cursor.execute('select * from user where id=?', '1')
<sqlite3.cursor object="" at="" 0x10f8aa340="">
# 獲得查詢(xún)結(jié)果集:
>>> values = cursor.fetchall()
>>> values
[(u'1', u'Michael')]
>>> cursor.close()
>>> conn.close()
</sqlite3.cursor>
使用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 id=?', '1')
SQLite支持常見(jiàn)的標(biāo)準(zhǔn)SQL語(yǔ)句以及幾種常見(jiàn)的數(shù)據(jù)類(lèi)型。具體文檔請(qǐng)參閱SQLite官方網(wǎng)站。
小結(jié)
在Python中操作數(shù)據(jù)庫(kù)時(shí),要先導(dǎo)入數(shù)據(jù)庫(kù)對(duì)應(yīng)的驅(qū)動(dòng),然后,通過(guò)Connection對(duì)象和Cursor對(duì)象操作數(shù)據(jù)。
要確保打開(kāi)的Connection對(duì)象和Cursor對(duì)象都正確地被關(guān)閉,否則,資源就會(huì)泄露。
如何才能確保出錯(cuò)的情況下也關(guān)閉掉Connection對(duì)象和Cursor對(duì)象呢?請(qǐng)回憶try:...except:...finally:...的用法。
知識(shí)點(diǎn)擴(kuò)充
SQLite3簡(jiǎn)介
SQLite3 可使用 sqlite3 模塊與 Python 進(jìn)行集成。sqlite3 模塊是由 Gerhard Haring 編寫(xiě)的。它提供了一個(gè)與 PEP 249 描述的 DB-API 2.0 規(guī)范兼容的 SQL 接口。您不需要單獨(dú)安裝該模塊,因?yàn)?Python 2.5.x 以上版本默認(rèn)自帶了該模塊。
為了使用 sqlite3 模塊,您首先必須創(chuàng)建一個(gè)表示數(shù)據(jù)庫(kù)的連接對(duì)象,然后您可以有選擇地創(chuàng)建光標(biāo)對(duì)象,這將幫助您執(zhí)行所有的 SQL 語(yǔ)句。
怎么樣,聽(tīng)起來(lái)不錯(cuò)吧!那就快來(lái)學(xué)習(xí)使用吧。
連接數(shù)據(jù)庫(kù)
下面的 Python 代碼顯示了如何連接到一個(gè)現(xiàn)有的數(shù)據(jù)庫(kù)。如果數(shù)據(jù)庫(kù)不存在,那么它就會(huì)被創(chuàng)建,最后將返回一個(gè)數(shù)據(jù)庫(kù)對(duì)象。
#-*- coding:utf-8 -*-
import sqlite3
conn = sqlite3.connect('mysql_person.db')
print "Opened database successfully";
在這里,您也可以把數(shù)據(jù)庫(kù)名稱(chēng)復(fù)制為特定的名稱(chēng) :memory:,這樣就會(huì)在 RAM 中創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)?,F(xiàn)在,讓我們來(lái)運(yùn)行上面的程序,在當(dāng)前目錄中創(chuàng)建我們的數(shù)據(jù)庫(kù) mysql_person.db。您可以根據(jù)需要改變路徑。保存上面代碼到 sqlite.py 文件中,并按如下所示執(zhí)行。如果數(shù)據(jù)庫(kù)成功創(chuàng)建,那么會(huì)顯示下面所示的消息:
$chmod +x sqlite.py $./sqlite.py Open database successfully
到此這篇關(guān)于Python中SQLite如何使用的文章就介紹到這了,更多相關(guān)Python中SQLite的簡(jiǎn)單應(yīng)用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
VSCode配合pipenv搞定虛擬環(huán)境的實(shí)現(xiàn)方法
這篇文章主要介紹了VSCode配合pipenv搞定虛擬環(huán)境的實(shí)現(xiàn)方法,文中通過(guò)圖文教程介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
解決pycharm不能自動(dòng)補(bǔ)全第三方庫(kù)的函數(shù)和屬性問(wèn)題
這篇文章主要介紹了解決pycharm不能自動(dòng)補(bǔ)全第三方庫(kù)的函數(shù)和屬性問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-03-03
使用Python開(kāi)發(fā)一個(gè)圖像標(biāo)注與OCR識(shí)別工具
這篇文章主要介紹了一個(gè)使用Python開(kāi)發(fā)的工具,允許用戶(hù)在圖像上進(jìn)行矩形標(biāo)注,使用 OCR 對(duì)標(biāo)注區(qū)域進(jìn)行文本識(shí)別,并將結(jié)果保存為 Excel 文件,感興趣的可以了解下2025-03-03
python 定時(shí)器,輪詢(xún)定時(shí)器的實(shí)例
今天小編就為大家分享一篇python 定時(shí)器,輪詢(xún)定時(shí)器的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-02-02
如何解決django-celery啟動(dòng)后迅速關(guān)閉
在本篇文章里小編給大家整理的是關(guān)于django-celery啟動(dòng)后迅速關(guān)閉的解決方法,有需要的朋友們學(xué)習(xí)下。2019-10-10
對(duì)python numpy.array插入一行或一列的方法詳解
今天小編就為大家分享一篇對(duì)python numpy.array插入一行或一列的方法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
drf-router和authenticate認(rèn)證源碼分析
在 Rest Framework 中提供了兩個(gè) router , 可以幫助我們快速的實(shí)現(xiàn)路由的自動(dòng)生成,本文通過(guò)實(shí)例代碼給大家介紹drf-router和authenticate認(rèn)證源碼分析,感興趣的朋友跟隨小編一起看看吧2021-07-07
基于Python+Flask實(shí)現(xiàn)一個(gè)簡(jiǎn)易網(wǎng)頁(yè)驗(yàn)證碼登錄系統(tǒng)案例
當(dāng)今的互聯(lián)網(wǎng)世界中,為了防止惡意訪問(wèn),許多網(wǎng)站在登錄和注冊(cè)表單中都采用了驗(yàn)證碼技術(shù),驗(yàn)證碼可以防止機(jī)器人自動(dòng)提交表單,確保提交行為背后有一個(gè)真實(shí)的人類(lèi)用戶(hù),本文將向您展示如何使用Python的Flask框架來(lái)創(chuàng)建一個(gè)簡(jiǎn)單的驗(yàn)證碼登錄系統(tǒng)2023-09-09
Python3內(nèi)置模塊random隨機(jī)方法小結(jié)
這篇文章主要介紹了Python3內(nèi)置模塊random隨機(jī)方法小結(jié),random是Python中與隨機(jī)數(shù)相關(guān)的模塊,其本質(zhì)就是一個(gè)偽隨機(jī)數(shù)生成器,我們可以利用random模塊基礎(chǔ)生成各種不同的隨機(jī)數(shù),以及一些基于隨機(jī)數(shù)的操作,需要的朋友可以參考下2019-07-07

