亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

Python中SQLite如何使用

瀏覽:60日期:2022-07-24 11:21:12

SQLite是一種嵌入式數(shù)據(jù)庫,它的數(shù)據(jù)庫就是一個(gè)文件。由于SQLite本身是C寫的,而且體積很小,所以,經(jīng)常被集成到各種應(yīng)用程序中,甚至在iOS和Android的App中都可以集成。Python就內(nèi)置了SQLite3,所以,在Python中使用SQLite,不需要安裝任何東西,直接使用。

在使用SQLite前,我們先要搞清楚幾個(gè)概念:

表是數(shù)據(jù)庫中存放關(guān)系數(shù)據(jù)的集合,一個(gè)數(shù)據(jù)庫里面通常都包含多個(gè)表,比如學(xué)生的表,班級的表,學(xué)校的表,等等。表和表之間通過外鍵關(guān)聯(lián)。

要操作關(guān)系數(shù)據(jù)庫,首先需要連接到數(shù)據(jù)庫,一個(gè)數(shù)據(jù)庫連接稱為Connection;

連接到數(shù)據(jù)庫后,需要打開游標(biāo),稱之為Cursor,通過Cursor執(zhí)行SQL語句,然后,獲得執(zhí)行結(jié)果。

Python定義了一套操作數(shù)據(jù)庫的API接口,任何數(shù)據(jù)庫要連接到Python,只需要提供符合Python標(biāo)準(zhǔn)的數(shù)據(jù)庫驅(qū)動(dòng)即可。

由于SQLite的驅(qū)動(dòng)內(nèi)置在Python標(biāo)準(zhǔn)庫中,所以我們可以直接來操作SQLite數(shù)據(jù)庫。

我們在Python交互式命令行實(shí)踐一下:

# 導(dǎo)入SQLite驅(qū)動(dòng):>>> import sqlite3# 連接到SQLite數(shù)據(jù)庫# 數(shù)據(jù)庫文件是test.db# 如果文件不存在,會(huì)自動(dòng)在當(dāng)前目錄創(chuàng)建:>>> conn = sqlite3.connect(’test.db’)# 創(chuàng)建一個(gè)Cursor:>>> cursor = conn.cursor()# 執(zhí)行一條SQL語句,創(chuàng)建user表:>>> cursor.execute(’create table user (id varchar(20) primary key, name varchar(20))’)<sqlite3.cursor object='' at='' 0x10f8aa260=''># 繼續(xù)執(zhí)行一條SQL語句,插入一條記錄:>>> cursor.execute(’insert into user (id, name) values (’1’, ’Michael’)’)# 通過rowcount獲得插入的行數(shù):>>> cursor.rowcount1# 關(guān)閉Cursor:>>> cursor.close()# 提交事務(wù):>>> conn.commit()# 關(guān)閉Connection:>>> conn.close()</sqlite3.cursor></sqlite3.cursor>

我們再試試查詢記錄:

>>> conn = sqlite3.connect(’test.db’)>>> cursor = conn.cursor()# 執(zhí)行查詢語句:>>> cursor.execute(’select * from user where id=?’, ’1’)<sqlite3.cursor object='' at='' 0x10f8aa340=''># 獲得查詢結(jié)果集:>>> values = cursor.fetchall()>>> values[(u’1’, u’Michael’)]>>> cursor.close()>>> conn.close()</sqlite3.cursor>

使用Python的DB-API時(shí),只要搞清楚Connection和Cursor對象,打開后一定記得關(guān)閉,就可以放心地使用。

使用Cursor對象執(zhí)行insert,update,delete語句時(shí),執(zhí)行結(jié)果由rowcount返回影響的行數(shù),就可以拿到執(zhí)行結(jié)果。

使用Cursor對象執(zhí)行select語句時(shí),通過featchall()可以拿到結(jié)果集。結(jié)果集是一個(gè)list,每個(gè)元素都是一個(gè)tuple,對應(yīng)一行記錄。

如果SQL語句帶有參數(shù),那么需要把參數(shù)按照位置傳遞給execute()方法,有幾個(gè)?占位符就必須對應(yīng)幾個(gè)參數(shù),例如:

cursor.execute(’select * from user where id=?’, ’1’)

SQLite支持常見的標(biāo)準(zhǔn)SQL語句以及幾種常見的數(shù)據(jù)類型。具體文檔請參閱SQLite官方網(wǎng)站。

小結(jié)

在Python中操作數(shù)據(jù)庫時(shí),要先導(dǎo)入數(shù)據(jù)庫對應(yīng)的驅(qū)動(dòng),然后,通過Connection對象和Cursor對象操作數(shù)據(jù)。

要確保打開的Connection對象和Cursor對象都正確地被關(guān)閉,否則,資源就會(huì)泄露。

如何才能確保出錯(cuò)的情況下也關(guān)閉掉Connection對象和Cursor對象呢?請回憶try:...except:...finally:...的用法。

知識點(diǎn)擴(kuò)充

SQLite3簡介

SQLite3 可使用 sqlite3 模塊與 Python 進(jìn)行集成。sqlite3 模塊是由 Gerhard Haring 編寫的。它提供了一個(gè)與 PEP 249 描述的 DB-API 2.0 規(guī)范兼容的 SQL 接口。您不需要單獨(dú)安裝該模塊,因?yàn)?Python 2.5.x 以上版本默認(rèn)自帶了該模塊。為了使用 sqlite3 模塊,您首先必須創(chuàng)建一個(gè)表示數(shù)據(jù)庫的連接對象,然后您可以有選擇地創(chuàng)建光標(biāo)對象,這將幫助您執(zhí)行所有的 SQL 語句。

怎么樣,聽起來不錯(cuò)吧!那就快來學(xué)習(xí)使用吧。

連接數(shù)據(jù)庫

下面的 Python 代碼顯示了如何連接到一個(gè)現(xiàn)有的數(shù)據(jù)庫。如果數(shù)據(jù)庫不存在,那么它就會(huì)被創(chuàng)建,最后將返回一個(gè)數(shù)據(jù)庫對象。

#-*- coding:utf-8 -*-import sqlite3conn = sqlite3.connect(’mysql_person.db’)print 'Opened database successfully';

在這里,您也可以把數(shù)據(jù)庫名稱復(fù)制為特定的名稱 :memory:,這樣就會(huì)在 RAM 中創(chuàng)建一個(gè)數(shù)據(jù)庫。現(xiàn)在,讓我們來運(yùn)行上面的程序,在當(dāng)前目錄中創(chuàng)建我們的數(shù)據(jù)庫 mysql_person.db。您可以根據(jù)需要改變路徑。保存上面代碼到 sqlite.py 文件中,并按如下所示執(zhí)行。如果數(shù)據(jù)庫成功創(chuàng)建,那么會(huì)顯示下面所示的消息:

$chmod +x sqlite.py$./sqlite.pyOpen database successfully

到此這篇關(guān)于Python中SQLite如何使用的文章就介紹到這了,更多相關(guān)Python中SQLite的簡單應(yīng)用內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 国产精品第一页在线 | 欧美在线视频网站 | 在线视频一二三区 | 免费黄色一级片 | 香蕉视频好色先生 | 午夜性刺激在线观看视频 | 色婷婷久久综合中文久久一本` | 91成人免费福利网站在线 | 亚洲综合激情六月婷婷在线观看 | 玖玖爱在线播放 | 精品精品久久宅男的天堂 | 国产精品成人第一区 | 国产一区二区日韩欧美在线 | 国产伦精品一区二区三区视频金莲 | 亚洲伦理一区二区 | 极品国产高颜值露脸在线 | 在线免费黄色 | 欧美伦理一区二区三区 | 国产又大又硬又粗又湿 | 五月天综合婷婷 | 亚洲综合久久一本伊伊区 | 中国一级性生活片 | 24小时中文乱码字幕在线观看 | 久久9966精品国产免费 | 欧洲一级做a爱在线观看 | 亚洲狠狠网站色噜噜 | 欧美日韩影视 | 亚洲综合久久久 | 亚洲精品自产拍在线观看 | 日韩精品亚洲专区在线影视 | 91久久国产青草亚洲 | 欧美高清一区二区三区欧美 | 米奇精品一区二区三区在线观看 | 国产色婷婷视频在线观看 | 成人娱乐网 | 久久中文字幕制服丝袜美腿 | 国产在线欧美精品 | 黄色一级视频在线播放 | 国产免费爽爽视频免费可以看 | 国产夜趣福利免费视频 | 国产精品一区二区无线 |