千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 使用Python操作SQLite數(shù)據(jù)庫

使用Python操作SQLite數(shù)據(jù)庫

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-07-21 16:13:58 1689927238

一、SQLite簡介

SQLite是一款輕量級的數(shù)據(jù)庫,旨在提供一個基本的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)。SQLite一般用于本地數(shù)據(jù)存儲,例如存儲應(yīng)用程序的用戶信息、位置信息等。SQLite與Python的結(jié)合可以用于開發(fā)移動應(yīng)用、網(wǎng)絡(luò)服務(wù)器、桌面應(yīng)用程序等。
Python中自帶了SQLite3模塊,可以非常方便地操作SQLite數(shù)據(jù)庫。

二、安裝SQLite3

在Python中,SQLite3是內(nèi)置的模塊,因此不需要額外的安裝。需要注意的是,如果使用的Python版本不是3.4以上版本,需要先安裝SQLite3。

# 安裝SQLite3
$ sudo apt-get install sqlite3 libsqlite3-dev

三、連接SQLite數(shù)據(jù)庫

連接SQLite數(shù)據(jù)庫可以通過Python的 connect()方法實現(xiàn)。

import sqlite3

# 連接到SQLite數(shù)據(jù)庫
conn = sqlite3.connect('example.db')

四、創(chuàng)建表格

在SQLite數(shù)據(jù)庫中創(chuàng)建表格可以使用Python的 execute()方法執(zhí)行SQL語句。

import sqlite3

# 連接到SQLite數(shù)據(jù)庫
conn = sqlite3.connect('example.db')

# 創(chuàng)建表格
conn.execute('''CREATE TABLE COMPANY
             (ID INT PRIMARY KEY NOT NULL,
             NAME TEXT NOT NULL,
             AGE INT NOT NULL,
             ADDRESS CHAR(50),
             SALARY REAL);''')
print("Table created successfully")

# 關(guān)閉數(shù)據(jù)庫連接
conn.close()

五、插入數(shù)據(jù)

使用Python的 execute()方法執(zhí)行SQL語句插入數(shù)據(jù)。

import sqlite3

# 連接到SQLite數(shù)據(jù)庫
conn = sqlite3.connect('example.db')

# 插入數(shù)據(jù)
conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
               VALUES (1, 'Paul', 32, 'California', 20000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
               VALUES (2, 'Allen', 25, 'Texas', 15000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
               VALUES (3, 'Teddy', 23, 'Norway', 20000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
               VALUES (4, 'Mark', 25, 'Rich-Mond', 65000.00 )")

# 提交數(shù)據(jù)庫執(zhí)行操作
conn.commit()
print("Records created successfully")

# 關(guān)閉數(shù)據(jù)庫連接
conn.close()

六、查詢數(shù)據(jù)

使用Python的 execute()方法執(zhí)行SQL語句查詢數(shù)據(jù)。

import sqlite3

# 連接到SQLite數(shù)據(jù)庫
conn = sqlite3.connect('example.db')

# 查詢數(shù)據(jù)
cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
   print("ID = ", row[0])
   print("NAME = ", row[1])
   print("ADDRESS = ", row[2])
   print("SALARY = ", row[3], "\n")

# 關(guān)閉數(shù)據(jù)庫連接
conn.close()

七、更新數(shù)據(jù)

使用Python的 execute()方法執(zhí)行SQL語句更新數(shù)據(jù)。

import sqlite3

# 連接到SQLite數(shù)據(jù)庫
conn = sqlite3.connect('example.db')

# 更新數(shù)據(jù)
conn.execute("UPDATE COMPANY set SALARY = 25000.00 where ID = 1")
conn.commit()
print("Total number of rows updated :", conn.total_changes)

# 查詢更新后的結(jié)果
cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
   print("ID = ", row[0])
   print("NAME = ", row[1])
   print("ADDRESS = ", row[2])
   print("SALARY = ", row[3], "\n")

# 關(guān)閉數(shù)據(jù)庫連接
conn.close()

八、刪除數(shù)據(jù)

使用Python的 execute()方法執(zhí)行SQL語句刪除數(shù)據(jù)。

import sqlite3

# 連接到SQLite數(shù)據(jù)庫
conn = sqlite3.connect('example.db')

# 刪除數(shù)據(jù)
conn.execute("DELETE from COMPANY where ID = 2;")
conn.commit()
print("Total number of rows deleted :", conn.total_changes)

# 查詢刪除后的結(jié)果
cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
   print("ID = ", row[0])
   print("NAME = ", row[1])
   print("ADDRESS = ", row[2])
   print("SALARY = ", row[3], "\n")

# 關(guān)閉數(shù)據(jù)庫連接
conn.close()
tags: python教程
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
為什么Hadoop是用Java實現(xiàn)的?

一、跨平臺能力多平臺運行:Java的“一次編寫,到處運行”理念,使得Hadoop能在各種操作系統(tǒng)和硬件上運行,不需要特定的調(diào)整。廣泛應(yīng)用:這一特...詳情>>

2023-10-15 16:51:37
ECU是什么?

1、ECU的基本定義與作用ECU,全稱為電子控制單元,是一種專門用于控制汽車各個系統(tǒng)的微處理器控制系統(tǒng)。通過接收傳感器的信號并轉(zhuǎn)換成控制指令...詳情>>

2023-10-15 16:29:54
什么是SOA?

1、SOA的基本概念與核心原則SOA是一種使軟件組件通過網(wǎng)絡(luò)進行互操作的架構(gòu)模式。核心原則包括:可發(fā)現(xiàn)的服務(wù):服務(wù)應(yīng)容易發(fā)現(xiàn)和理解。松耦合:...詳情>>

2023-10-15 16:19:32
什么是內(nèi)存池?

1、內(nèi)存池的基本概念內(nèi)存池是一種內(nèi)存管理策略,旨在優(yōu)化內(nèi)存分配性能和減少碎片化。通過將內(nèi)存分配到大小固定的池中,應(yīng)用程序可以快速、高效...詳情>>

2023-10-15 16:16:15
ci構(gòu)建與編譯的區(qū)別是什么?

一、功能與目的構(gòu)建(Build): 構(gòu)建是將源代碼轉(zhuǎn)化為可執(zhí)行代碼的過程,它包括編譯、鏈接、打包等一系列步驟。構(gòu)建不僅僅局限于編譯,還可能涉...詳情>>

2023-10-15 15:57:11