在Python中使用SQLite的簡單教程

來源:互聯網
上載者:User
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))')# 繼續執行一條SQL語句,插入一條記錄:>>> cursor.execute('insert into user (id, name) values (\'1\', \'Michael\')')# 通過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')# 獲得查詢結果集:>>> 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()方法,有幾個?預留位置就必須對應幾個參數,例如:

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

SQLite支援常見的標準SQL語句以及幾種常見的資料類型。具體文檔請參閱SQLite官方網站。
小結

在Python中操作資料庫時,要先匯入資料庫對應的驅動,然後,通過Connection對象和Cursor對象操作資料。

要確保開啟的Connection對象和Cursor對象都正確地被關閉,否則,資源就會泄露。

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

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.