Python2.7編程中SQLite3基本操作方法示例
本文實(shí)例講述了Python2.7中SQLite3基本操作方法。分享給大家供大家參考,具體如下:
1、基本操作
# -*- coding: utf-8 -*-
#!/usr/bin/env python
import sqlite3
def mykey(x):
return x[3]
conn=sqlite3.connect("D:\\demo\\my_db.db")
sql = "CREATE TABLE IF NOT EXISTS mytb ( a char , b int , c real, d DATE)"
# a char , b int , c real 表示該表有三個(gè)字段,
# a 是字符串類型, b 是整數(shù)類型, c 是實(shí)數(shù)類型。
conn.execute( sql )
cs = conn.cursor()
#cs.execute("DELETE FROM mytb WHERE A='張三' ")
cs.execute("DELETE FROM mytb ")
#刪除所有記錄
'''''
cs.execute( "INSERT INTO mytb ( a,b,c,d ) values('Zhang San',25, 120, '2014-03-04')" )
cs.execute( "INSERT INTO mytb ( a,b,c,d ) values( 'Wang Wu',24, 110, '2014-05-01')" )
cs.execute( "INSERT INTO mytb ( a,b,c,d ) values( 'Li Si',23, 130, '2014-04-06')" )
'''
#批量注入,batchdata是一個(gè)列表,列表里每一個(gè)元素都是一個(gè)元組
batchdata=[('Zhang San',25, 120, '2014-03-04'),
( 'Wang Wu',24, 110, '2014-05-01'),
( 'Li Si',23, 130, '2014-04-06')]
cs.executemany('INSERT INTO mytb values (?,?,?,?)',batchdata)
conn.commit() #將加入的記錄保存到磁盤,非常重要!
cs.execute("SELECT name, sql FROM sqlite_master WHERE type='table'")
recs = cs.fetchall( )
print ( recs )
cs.execute( "SELECT * FROM mytb ")#打開數(shù)據(jù)表
recs = cs.fetchall()#取出所有記錄
print ( "there is ", len(recs)," notes." )
print recs
recs.sort(key = mykey)
print recs
cs.close()
conn.close()
2、刪除一條記錄,使用sql字符串變量可以實(shí)現(xiàn)帶參數(shù)的刪除
sql="DELETE FROM my_table WHERE number='" + my_num + "'" cs.execute(sql)
3、查詢某一條或多條記錄
如果SQLite3查找的數(shù)據(jù)庫記錄中含有中文,取出到Python時(shí)要對(duì)數(shù)據(jù)進(jìn)行decode處理。當(dāng)時(shí)我上網(wǎng)查的時(shí)候說要用GBK解碼,但我自己卻解碼失敗了,換成utf-8解碼才成功顯示。 另外,如果只查詢一條可以用fetchone語句,或者fetchall之后再通過python把它找出來。
sql="SELECT name FROM my_table WHERE number ='" + my_num + "'"
cs.execute(sql)
the_name=(cs.fetchall())[0][0].decode('utf-8')
4、避免重復(fù)注入
有時(shí)候我們會(huì)有重復(fù)的記錄,為了避免把相同的記錄多次插入到數(shù)據(jù)庫,可以使用如下語句:
sql="INSERT OR REPLACE INTO "+my_table+" values (?,?,?,?,?,?,?) " #假設(shè)my_table有7項(xiàng)
5、插入中文記錄至SQLite3
Python是unicode編碼,但數(shù)據(jù)庫對(duì)中文是使用GBK編碼,比如stock_name變量含有中文,則需要做unicode(name, "gbk")處理
batch=[(stock_num, unicode(stock_name, "gbk") )] cs.executemany( "INSERT OR REPLACE INTO my_table values (?,?) ",batch)
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python操作SQLite數(shù)據(jù)庫技巧總結(jié)》、《Python常見數(shù)據(jù)庫操作技巧匯總》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- Python操作sqlite3快速、安全插入數(shù)據(jù)(防注入)的實(shí)例
- python操作數(shù)據(jù)庫之sqlite3打開數(shù)據(jù)庫、刪除、修改示例
- Python Sqlite3以字典形式返回查詢結(jié)果的實(shí)現(xiàn)方法
- Python sqlite3事務(wù)處理方法實(shí)例分析
- Python SQLite3數(shù)據(jù)庫日期與時(shí)間常見函數(shù)用法分析
- Python開發(fā)SQLite3數(shù)據(jù)庫相關(guān)操作詳解【連接,查詢,插入,更新,刪除,關(guān)閉等】
- Python實(shí)現(xiàn)讀寫sqlite3數(shù)據(jù)庫并將統(tǒng)計(jì)數(shù)據(jù)寫入Excel的方法示例
- Python Web框架Flask下網(wǎng)站開發(fā)入門實(shí)例
- 30分鐘搭建Python的Flask框架并在上面編寫第一個(gè)應(yīng)用
- Python的Flask框架與數(shù)據(jù)庫連接的教程
- Python使用flask框架操作sqlite3的兩種方式
相關(guān)文章
windows server 2008 r2 標(biāo)準(zhǔn)版安裝python環(huán)境
本文主要介紹了windows server 2008 r2 標(biāo)準(zhǔn)版安裝python環(huán)境,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
Python Flask token身份認(rèn)證的示例代碼(附完整代碼)
在Web應(yīng)用中,經(jīng)常需要進(jìn)行身份認(rèn)證,以確保只有授權(quán)用戶才能訪問某些資源,本文主要介紹了Python Flask token身份認(rèn)證的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11
YOLOv5部署到web端詳細(xì)過程(flask+js簡單易懂)
YOLOv5是一個(gè)目標(biāo)檢測模型,Flask是一個(gè)Python的Web框架,下面這篇文章主要給大家介紹了關(guān)于YOLOv5部署到web端(flask+js簡單易懂)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04
Django自帶的用戶驗(yàn)證系統(tǒng)實(shí)現(xiàn)
這篇文章主要介紹了Django自帶的用戶驗(yàn)證系統(tǒng)實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
Python+Dlib+Opencv實(shí)現(xiàn)人臉采集并表情判別功能的代碼
這篇文章主要介紹了Python+Dlib+Opencv實(shí)現(xiàn)人臉采集并表情判別,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
python使用pooch實(shí)現(xiàn)下載網(wǎng)絡(luò)文件
pooch是python的一個(gè)模塊,主打一個(gè)更加方便地下載文件,適用于科研人員和開發(fā)者,目前,已經(jīng)有scikit-image, MetPy, scipy, seaborn等項(xiàng)目采用pooch作為內(nèi)置數(shù)據(jù)集的下載方法,本文給大家介紹了python用pooch便捷地下載網(wǎng)絡(luò)文件,需要的朋友可以參考下2024-01-01

