Python中如何使用sqlite3操作SQLite數(shù)據(jù)庫詳解
前言
在 Python 開發(fā)中,SQLite 是一種輕量級的關(guān)系型數(shù)據(jù)庫,它無需單獨安裝數(shù)據(jù)庫服務(wù)器,所有數(shù)據(jù)存儲在一個單獨的文件中,適用于小型應(yīng)用、移動開發(fā)、數(shù)據(jù)分析等場景。Python 提供了內(nèi)置的 sqlite3
模塊,方便我們操作 SQLite 數(shù)據(jù)庫。本文將詳細介紹 sqlite3
模塊的使用,包括數(shù)據(jù)庫連接、表操作、數(shù)據(jù)增刪改查(CRUD),以及常見的事務(wù)管理和參數(shù)化查詢,幫助你快速掌握 Python 操作 SQLite 數(shù)據(jù)庫的方法。
1. 為什么選擇 SQLite?
? 零配置:Python 內(nèi)置支持,無需安裝額外數(shù)據(jù)庫服務(wù)。
? 文件存儲:數(shù)據(jù)庫僅是一個 .db
文件,便于管理。
? 輕量高效:適用于小型應(yīng)用、測試環(huán)境、移動端存儲。
? SQL 支持:支持 SQL 語法,易于與其他數(shù)據(jù)庫遷移。
?? SQLite 適用場景:
- 桌面應(yīng)用(如瀏覽器、記事本應(yīng)用存儲用戶數(shù)據(jù))。
- 移動應(yīng)用(Android、iOS 本地數(shù)據(jù)庫)。
- 數(shù)據(jù)分析(存儲小型數(shù)據(jù)集,替代 CSV 文件)。
2. 連接 SQLite 數(shù)據(jù)庫
2.1 連接或創(chuàng)建數(shù)據(jù)庫
使用 sqlite3.connect()
連接數(shù)據(jù)庫:
import sqlite3 # 連接數(shù)據(jù)庫(如果不存在則創(chuàng)建) conn = sqlite3.connect("example.db") print("數(shù)據(jù)庫連接成功")
?? 特點:
- 如果
example.db
存在,則連接它,否則自動創(chuàng)建該文件。
2.2 獲取游標(Cursor)
數(shù)據(jù)庫操作需要使用 游標對象(cursor):
cursor = conn.cursor()
?? 作用:
cursor.execute(sql)
用于執(zhí)行 SQL 語句。cursor.fetchall()
獲取查詢結(jié)果。
3. 創(chuàng)建表(CREATE TABLE)
使用 CREATE TABLE
語句創(chuàng)建數(shù)據(jù)庫表:
cursor.execute(''' CREATE TABLE IF NOT EXISTS users ( id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, age INTEGER, city TEXT ) ''') conn.commit() # 提交更改 print("表創(chuàng)建成功")
?? 解析:
id INTEGER PRIMARY KEY AUTOINCREMENT
:主鍵自增。TEXT NOT NULL
:name
必須有值。IF NOT EXISTS
:避免重復(fù)創(chuàng)建表。
4. 插入數(shù)據(jù)(INSERT INTO)
4.1 插入單條數(shù)據(jù)
cursor.execute("INSERT INTO users (name, age, city) VALUES (?, ?, ?)", ("Alice", 25, "New York")) conn.commit() print("插入數(shù)據(jù)成功")
?? 注意:
?
占位符 避免 SQL 注入。conn.commit()
提交事務(wù),否則數(shù)據(jù)不會保存。
4.2 插入多條數(shù)據(jù)(executemany())
users = [ ("Bob", 30, "San Francisco"), ("Charlie", 28, "Los Angeles"), ("David", 35, "Seattle") ] cursor.executemany("INSERT INTO users (name, age, city) VALUES (?, ?, ?)", users) conn.commit() print("批量插入成功")
?? 適用于:
- 批量寫入數(shù)據(jù),避免多次
execute()
提高效率。
5. 查詢數(shù)據(jù)(SELECT)
5.1 查詢所有數(shù)據(jù)
cursor.execute("SELECT * FROM users") rows = cursor.fetchall() for row in rows: print(row)
?? fetchall() 獲取所有數(shù)據(jù),返回列表:
(1, 'Alice', 25, 'New York') (2, 'Bob', 30, 'San Francisco') (3, 'Charlie', 28, 'Los Angeles')
5.2 查詢單條數(shù)據(jù)(fetchone())
cursor.execute("SELECT * FROM users WHERE name = ?", ("Alice",)) user = cursor.fetchone() print(user)
?? fetchone() 獲取單條數(shù)據(jù),適用于查詢唯一記錄。
6. 更新數(shù)據(jù)(UPDATE)
cursor.execute("UPDATE users SET age = ? WHERE name = ?", (26, "Alice")) conn.commit() print("數(shù)據(jù)更新成功")
?? 確保:
SET age = ?
只更新age
列,避免誤修改其他數(shù)據(jù)。
7. 刪除數(shù)據(jù)(DELETE)
cursor.execute("DELETE FROM users WHERE name = ?", ("David",)) conn.commit() print("數(shù)據(jù)刪除成功")
?? 務(wù)必小心:
- 沒有 WHERE 條件會刪除所有數(shù)據(jù)!
- 先
SELECT
確認數(shù)據(jù)是否存在。
8. 事務(wù)管理(commit() 和 rollback())
8.1 commit() 提交事務(wù)
conn.commit() # 確保數(shù)據(jù)寫入數(shù)據(jù)庫
?? 每次 INSERT、UPDATE、DELETE 后,都要 commit() 確保數(shù)據(jù)持久化。
8.2 rollback() 回滾事務(wù)
try: cursor.execute("UPDATE users SET age = ? WHERE name = ?", (100, "Charlie")) raise Exception("模擬異常") # 模擬錯誤 conn.commit() except Exception as e: conn.rollback() # 發(fā)生錯誤時回滾 print("事務(wù)回滾:", e)
?? 作用:
- 如果操作失敗,回滾到上一次
commit()
,防止錯誤影響數(shù)據(jù)庫。
9. 關(guān)閉數(shù)據(jù)庫連接
cursor.close() conn.close() print("數(shù)據(jù)庫連接已關(guān)閉")
?? 最佳實踐:
- 完成所有數(shù)據(jù)庫操作后,應(yīng)關(guān)閉連接,釋放資源。
10. 結(jié)合 with 語句自動管理連接
Python 提供 with
語法,自動關(guān)閉數(shù)據(jù)庫連接:
with sqlite3.connect("example.db") as conn: cursor = conn.cursor() cursor.execute("SELECT * FROM users") print(cursor.fetchall())
?? 優(yōu)勢:
- 自動 commit()
- 異常發(fā)生時自動 rollback()
- 退出時自動關(guān)閉 conn
11. 使用 Row 以字典方式訪問數(shù)據(jù)
默認 fetchall()
返回元組:
cursor.execute("SELECT * FROM users") print(cursor.fetchone()) # (1, 'Alice', 25, 'New York')
可以改用 sqlite3.Row
使數(shù)據(jù)可用字典訪問:
conn.row_factory = sqlite3.Row # 設(shè)置行工廠 cursor = conn.cursor() cursor.execute("SELECT * FROM users") row = cursor.fetchone() print(row["name"], row["age"]) # Alice 25
?? 適用于:
- 提高可讀性,避免
row[0]
這樣的索引訪問方式。
12. 結(jié)論
操作 | 代碼示例 |
---|---|
連接數(shù)據(jù)庫 | conn = sqlite3.connect("example.db") |
創(chuàng)建表 | CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER) |
插入數(shù)據(jù) | INSERT INTO users (name, age) VALUES (?, ?) |
查詢數(shù)據(jù) | SELECT * FROM users |
更新數(shù)據(jù) | UPDATE users SET age = ? WHERE name = ? |
刪除數(shù)據(jù) | DELETE FROM users WHERE name = ? |
事務(wù)管理 | commit() / rollback() |
關(guān)閉連接 | conn.close() |
sqlite3
是 Python 內(nèi)置的數(shù)據(jù)庫模塊,適用于小型應(yīng)用、測試、數(shù)據(jù)存儲等場景。掌握這些操作,你就可以輕松管理 SQLite 數(shù)據(jù)庫,提升開發(fā)效率!
總結(jié)
到此這篇關(guān)于Python中如何使用sqlite3操作SQLite數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)Python sqlite3操作SQLite內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 使用Python連接SQLite數(shù)據(jù)庫的操作步驟
- 通過python封裝SQLite3的示例代碼
- Python數(shù)據(jù)庫編程之SQLite和MySQL的實踐指南
- Python的sqlite3模塊中常用函數(shù)
- Python中SQLite數(shù)據(jù)庫的使用
- Python數(shù)據(jù)庫sqlite3圖文實例詳解
- Python使用sqlite3第三方庫讀寫SQLite數(shù)據(jù)庫的方法步驟
- Python練習(xí)之操作SQLite數(shù)據(jù)庫
- python處理SQLite數(shù)據(jù)庫的方法
- SQLite5-使用Python來讀寫數(shù)據(jù)庫
- Pandas使用SQLite3實戰(zhàn)
相關(guān)文章
pycharm中:OSError:[WinError?1455]頁面文件太小無法完成操作問題的多種解決方法
這篇文章主要給大家介紹了關(guān)于pycharm中:OSError:[WinError?1455]頁面文件太小無法完成操作問題的多種徹底解決方法,文中通過圖文介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-02-02Python小工具之消耗系統(tǒng)指定大小內(nèi)存的方法
今天小編就為大家分享一篇Python小工具之消耗系統(tǒng)指定大小內(nèi)存的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12Scrapy之爬取結(jié)果導(dǎo)出為Excel的實現(xiàn)過程
這篇文章主要介紹了Scrapy之爬取結(jié)果導(dǎo)出為Excel的實現(xiàn)過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12python 點云地面點濾波-progressive TIN densification(PTD)算法介紹
關(guān)于地面點濾波的概念我們要與孤立點(outlier)濾波區(qū)分開,孤立點濾波可以理解為圖像中的去噪,去除數(shù)據(jù)測量過程中受到飛鳥、多路徑效應(yīng)所產(chǎn)生的遠低于/高于其他數(shù)據(jù)的點。今天通過本文給大家分享python PTD點云地面點濾波的相關(guān)知識,一起看看吧2021-08-08通過數(shù)據(jù)庫對Django進行刪除字段和刪除模型的操作
這篇文章主要介紹了通過數(shù)據(jù)庫對Django進行刪除字段和刪除模型的操作,這里假設(shè)我們已經(jīng)建立了一個名為book的數(shù)據(jù)模型,需要的朋友可以參考下2015-07-07