溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python如何使用executescript

發(fā)布時(shí)間:2020-09-24 13:08:49 來(lái)源:億速云 閱讀:249 作者:Leah 欄目:編程語(yǔ)言

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

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

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

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

# ①、打開或創(chuàng)建數(shù)據(jù)庫(kù)
# 也可以使用特殊名::memory:代表創(chuàng)建內(nèi)存中的數(shù)據(jù)庫(kù)
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 語(yǔ)句,該語(yǔ)句負(fù)責(zé)向 user_tb 表中插入記錄,還使用 create 語(yǔ)句創(chuàng)建了一個(gè)數(shù)據(jù)表。

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

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

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

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

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

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

關(guān)于Python如何使用executescript問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI