国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

在Python中使用SQLite的簡單教程

2020-02-23 00:59:10
字體:
來源:轉載
供稿:網友

SQLite是一種嵌入式數據庫,它的數據庫就是一個文件。由于SQLite本身是C寫的,而且體積很小,所以,經常被集成到各種應用程序中,甚至在iOS和Android的App中都可以集成。

Python就內置了SQLite3,所以,在Python中使用SQLite,不需要安裝任何東西,直接使用。

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

表是數據庫中存放關系數據的集合,一個數據庫里面通常都包含多個表,比如學生的表,班級的表,學校的表,等等。表和表之間通過外鍵關聯。

要操作關系數據庫,首先需要連接到數據庫,一個數據庫連接稱為Connection;

連接到數據庫后,需要打開游標,稱之為Cursor,通過Cursor執行SQL語句,然后,獲得執行結果。

Python定義了一套操作數據庫的API接口,任何數據庫要連接到Python,只需要提供符合Python標準的數據庫驅動即可。

由于SQLite的驅動內置在Python標準庫中,所以我們可以直接來操作SQLite數據庫。

我們在Python交互式命令行實踐一下:

# 導入SQLite驅動:>>> import sqlite3# 連接到SQLite數據庫# 數據庫文件是test.db# 如果文件不存在,會自動在當前目錄創建:>>> conn = sqlite3.connect('test.db')# 創建一個Cursor:>>> cursor = conn.cursor()# 執行一條SQL語句,創建user表:>>> cursor.execute('create table user (id varchar(20) primary key, name varchar(20))')<sqlite3.Cursor object at 0x10f8aa260># 繼續執行一條SQL語句,插入一條記錄:>>> cursor.execute('insert into user (id, name) values (/'1/', /'Michael/')')<sqlite3.Cursor object at 0x10f8aa260># 通過rowcount獲得插入的行數:>>> cursor.rowcount1# 關閉Cursor:>>> cursor.close()# 提交事務:>>> conn.commit()# 關閉Connection:>>> conn.close()

我們再試試查詢記錄:

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

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

使用Cursor對象執行insert,update,delete語句時,執行結果由rowcount返回影響的行數,就可以拿到執行結果。

使用Cursor對象執行select語句時,通過featchall()可以拿到結果集。結果集是一個list,每個元素都是一個tuple,對應一行記錄。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 栖霞市| 灵山县| 博客| 华池县| 奉贤区| 东莞市| 奉节县| 永定县| 石泉县| 驻马店市| 东乡族自治县| 股票| 杭锦后旗| 浦江县| 江陵县| 西畴县| 香港| 休宁县| 扎兰屯市| 建德市| 抚宁县| 理塘县| 清苑县| 犍为县| 巴青县| 中江县| 嵊州市| 阿坝| 海丰县| 印江| 西青区| 齐河县| 鸡西市| 海伦市| 鸡东县| 鹤壁市| 吴堡县| 晋中市| 韶山市| 肥东县| 雷波县|