欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python2.7編程中SQLite3基本操作方法示例

 更新時(shí)間:2017年08月09日 09:44:15   作者:hdc  
這篇文章主要介紹了Python2.7編程中SQLite3基本操作方法,涉及Python2.7操作sqlite3數(shù)據(jù)庫(kù)的增刪改查及防注入等相關(guān)技巧,需要的朋友可以參考下

本文實(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 是字符串類(lèi)型, b 是整數(shù)類(lèi)型, c 是實(shí)數(shù)類(lèi)型。
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() #將加入的記錄保存到磁盤(pán),非常重要!
cs.execute("SELECT name, sql FROM sqlite_master WHERE type='table'")
recs = cs.fetchall( )
print ( recs )
cs.execute( "SELECT * FROM mytb ")#打開(kāi)數(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ù)庫(kù)記錄中含有中文,取出到Python時(shí)要對(duì)數(shù)據(jù)進(jìn)行decode處理。當(dāng)時(shí)我上網(wǎng)查的時(shí)候說(shuō)要用GBK解碼,但我自己卻解碼失敗了,換成utf-8解碼才成功顯示。 另外,如果只查詢一條可以用fetchone語(yǔ)句,或者fetchall之后再通過(guò)python把它找出來(lái)。

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ù)庫(kù),可以使用如下語(yǔ)句:

sql="INSERT OR REPLACE INTO "+my_table+" values (?,?,?,?,?,?,?) "
#假設(shè)my_table有7項(xiàng)

5、插入中文記錄至SQLite3

Python是unicode編碼,但數(shù)據(jù)庫(kù)對(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)容感興趣的讀者可查看本站專(zhuān)題:《Python操作SQLite數(shù)據(jù)庫(kù)技巧總結(jié)》、《Python常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門(mén)與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • python selenium自動(dòng)化測(cè)試框架搭建的方法步驟

    python selenium自動(dòng)化測(cè)試框架搭建的方法步驟

    這篇文章主要介紹了python selenium自動(dòng)化測(cè)試框架搭建的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Python自動(dòng)修改電腦靜態(tài)IP地址的實(shí)現(xiàn)示例

    Python自動(dòng)修改電腦靜態(tài)IP地址的實(shí)現(xiàn)示例

    通過(guò)Python自動(dòng)修改電腦的靜態(tài)IP地址可以極大地提高我們的工作效率,減少手動(dòng)修改IP地址帶來(lái)的錯(cuò)誤,本文就來(lái)介紹一下Python自動(dòng)修改電腦靜態(tài)IP地址的實(shí)現(xiàn)示例,感興趣的可以了解一下
    2023-11-11
  • python selenium 對(duì)瀏覽器標(biāo)簽頁(yè)進(jìn)行關(guān)閉和切換的方法

    python selenium 對(duì)瀏覽器標(biāo)簽頁(yè)進(jìn)行關(guān)閉和切換的方法

    今天小編就為大家分享一篇python selenium 對(duì)瀏覽器標(biāo)簽頁(yè)進(jìn)行關(guān)閉和切換的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • django+mysql的使用示例

    django+mysql的使用示例

    django可以自動(dòng)生成這些create table, alter table, drop table的操作,這篇文章主要介紹了django+mysql的使用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • python替換字符串中的子串圖文步驟

    python替換字符串中的子串圖文步驟

    在本文里小編給大家整理了關(guān)于python替換字符串中的子串的相關(guān)知識(shí)點(diǎn)以及實(shí)際操作步驟,有需要的朋友們學(xué)習(xí)下。
    2019-06-06
  • Google開(kāi)源的Python格式化工具YAPF的安裝和使用教程

    Google開(kāi)源的Python格式化工具YAPF的安裝和使用教程

    Google的開(kāi)發(fā)者文檔中有一套Python的代碼書(shū)寫(xiě)規(guī)范,而在GitHub上同樣開(kāi)源了一款名為YAPF的命令行程序用作Python的格式化,下面我們就來(lái)看下這款Google開(kāi)源的Python格式化工具YAPF的安裝和使用教程
    2016-05-05
  • Python實(shí)現(xiàn)代碼統(tǒng)計(jì)工具(終極篇)

    Python實(shí)現(xiàn)代碼統(tǒng)計(jì)工具(終極篇)

    這篇文章主要介紹了Python實(shí)現(xiàn)代碼統(tǒng)計(jì)工具的相關(guān)資料,供大家參考,感興趣的小伙伴們可以參考一下
    2016-07-07
  • 如何使用Python多線程測(cè)試并發(fā)漏洞

    如何使用Python多線程測(cè)試并發(fā)漏洞

    這篇文章主要介紹了如何使用Python多線程測(cè)試并發(fā)漏洞,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • Python標(biāo)準(zhǔn)庫(kù)pickle的簡(jiǎn)單使用

    Python標(biāo)準(zhǔn)庫(kù)pickle的簡(jiǎn)單使用

    本文主要介紹了Python標(biāo)準(zhǔn)庫(kù)pickle的簡(jiǎn)單使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • 使用pandas的box_plot去除異常值

    使用pandas的box_plot去除異常值

    今天小編就為大家分享一篇使用pandas的box_plot去除異常值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-12-12

最新評(píng)論