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

