Python如何使用executescript

Python如何使用executescript?針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

創(chuàng)新互聯(lián)是一家以成都網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、品牌設(shè)計、軟件運維、成都網(wǎng)站推廣、小程序App開發(fā)等移動開發(fā)為一體互聯(lián)網(wǎng)公司。已累計為成都濕噴機等眾行業(yè)中小客戶提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開發(fā)服務(wù)。

SQLite 數(shù)據(jù)庫模塊的游標(biāo)對象還包含了一個 executescript() 方法,這不是一個標(biāo)準(zhǔn)的 API 方法,這意味著在其他數(shù)據(jù)庫 API 模塊中可能沒有這個方法。但是這個方法卻很實用,它可以執(zhí)行一段 SQL 腳本。

例如,如下程序使用 executescript() 方法執(zhí)行一段 SQL 腳本:

# 導(dǎo)入訪問SQLite的模塊
import sqlite3

# ①、打開或創(chuàng)建數(shù)據(jù)庫
# 也可以使用特殊名::memory:代表創(chuàng)建內(nèi)存中的數(shù)據(jù)庫
conn = sqlite3.connect('first.db')
# ②、獲取游標(biāo)
c = conn.cursor()
# ③、調(diào)用executescript()方法執(zhí)行一段SQL腳本
c.executescript('''
    insert into user_tb values(null, '武松', '3444', 'male'); 
    insert into user_tb values(null, '林沖', '44444', 'male');
    create table item_tb(_id integer primary key autoincrement, name, price);
    ''')
conn.commit()
# ④、關(guān)閉游標(biāo)
c.close()
# ⑤、關(guān)閉連接
conn.close()

上面程序調(diào)用 executescript() 方法執(zhí)行一段復(fù)雜的 SQL 腳本,在這段 SQL 腳本中包含了兩條 insert 語句,該語句負(fù)責(zé)向 user_tb 表中插入記錄,還使用 create 語句創(chuàng)建了一個數(shù)據(jù)表。

運行上面程序,可以看到 first.db 數(shù)據(jù)庫中多了一個 item_tb 數(shù)據(jù)表,user_tb 數(shù)據(jù)表被插入了兩條記錄。

此外,為了簡化編程,SQLite 數(shù)據(jù)庫模塊還為數(shù)據(jù)庫連接對象提供了如下 3 個方法:

execute(sql[, parameters]):執(zhí)行一條 SQL 語句。

executemany(sql[, parameters]):根據(jù)序列重復(fù)執(zhí)行 SQL 語句。

executescript(sql_script):執(zhí)行 SQL 腳本。

讀者可能會發(fā)現(xiàn),這 3 個方法與游標(biāo)對象所包含的 3 個方法完全相同。事實正是如此,數(shù)據(jù)庫連接對象的這 3 個方法都不是 DB API 2.0 的標(biāo)準(zhǔn)方法,它們只是游標(biāo)對象的 3 個方法的快捷方式,因此在用法上與游標(biāo)對象的 3 個方法完全相同。

關(guān)于Python如何使用executescript問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

文章題目:Python如何使用executescript
文章轉(zhuǎn)載:http://bm7419.com/article24/jjcjje.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)、Google、響應(yīng)式網(wǎng)站、網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站網(wǎng)頁設(shè)計公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)