溫馨提示×

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

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

Python數(shù)據(jù)庫(kù)sqlite3怎么創(chuàng)建并使用

發(fā)布時(shí)間:2022-09-20 09:37:18 來(lái)源:億速云 閱讀:212 作者:iii 欄目:開(kāi)發(fā)技術(shù)

本篇內(nèi)容介紹了“Python數(shù)據(jù)庫(kù)sqlite3怎么創(chuàng)建并使用”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

sqlite3數(shù)據(jù)庫(kù)

sqlite3 數(shù)據(jù)庫(kù)是 Python 自帶的數(shù)據(jù)庫(kù),甚至不需要額外安裝模塊,而且操作簡(jiǎn)單。

1.需要的模塊(只有一個(gè))

import sqlite3

2.模塊的使用

首先打開(kāi)我們的編譯器(推薦使用vscode,因?yàn)閿?shù)據(jù)庫(kù)文件后綴是 .db,vscode里顯示比較清楚)

2.1創(chuàng)建與數(shù)據(jù)庫(kù)的連接

先放上代碼

conn = sqlite3.connect('test.db')

使用 sqlite3 的 connect 函數(shù)可以創(chuàng)建數(shù)據(jù)庫(kù)或者連接數(shù)據(jù)庫(kù),

如果這個(gè)數(shù)據(jù)庫(kù)存在,就連接這個(gè)數(shù)據(jù)庫(kù),

如果這個(gè)庫(kù)不存在,就創(chuàng)建數(shù)據(jù)庫(kù)。

右邊小括號(hào)里的是數(shù)據(jù)庫(kù)名。

我們把這個(gè)保存在變量 conn 里,這個(gè)變量名可以自己起

公式:

變量名 = sqlite3.connect( '你要的數(shù)據(jù)庫(kù)名.db' )

2.2創(chuàng)建游標(biāo)

還是先放代碼

cur = conn.cursor()

在 2.1 中,我們創(chuàng)建了與數(shù)據(jù)庫(kù)的連接,我們現(xiàn)在還需要一個(gè)游標(biāo)來(lái)執(zhí)行 sql 命令,

所以我們要用 conn 的 cursor 函數(shù)創(chuàng)建一個(gè)游標(biāo)。

conn 就是剛才 2.1 中創(chuàng)建的保存數(shù)據(jù)庫(kù)的變量,你要用你定義的變量名,

再定義一個(gè)變量表示這個(gè)游標(biāo)。

公式:

變量 = 數(shù)據(jù)庫(kù)變量.cursor()

2.3創(chuàng)建 table

先放代碼

import sqlite3
def check(db_name,table_name):
    conn = sqlite3.connect(db_name)
    cursor = conn.cursor()
    sql = '''SELECT tbl_name FROM sqlite_master WHERE type = 'table' '''
    cursor.execute(sql)
    values = cursor.fetchall()
    tables = []
    for v in values:
        tables.append(v[0])
    if table_name not in tables:
        return False # 可以建表
    else:
        return True # 不能建表
conn = sqlite3.connect('數(shù)據(jù)庫(kù)名.db')
#創(chuàng)建一個(gè)游標(biāo) cursor
cur = conn.cursor()
if (check("數(shù)據(jù)庫(kù)名.db","Table名") == False):
    sql_text_1 = '''CREATE TABLE 你的table名
            (xx XX,
                xx XX);'''
    # 執(zhí)行sql語(yǔ)句
    cur.execute(sql_text_1)

代碼比較長(zhǎng),因?yàn)槲野?2.1 和 2.2 的兩行代碼也加了上去。

我們需要 table(表)來(lái)存數(shù)據(jù),創(chuàng)建 table 的代碼如下:

變量名 = '''CREATE TABLE 你的table名
            (xx XX,
                xx XX);'''
# 執(zhí)行sql語(yǔ)句
cur.execute(上面的變量名)

上面是用一個(gè)變量保存了創(chuàng)建 table 的 sql 語(yǔ)句,

下面使用 cur(就是剛才那個(gè)游標(biāo)).execute() 函數(shù)執(zhí)行創(chuàng)建 table 的語(yǔ)句。

我們也可以使用 cur.executemany 函數(shù)來(lái)同時(shí)執(zhí)行多條 sql 語(yǔ)句。

sql 語(yǔ)句的內(nèi)容,比如創(chuàng)建表的格式是上面這樣的

格式:' ' 'CREATE TABLE 你的 table 名 (xx XX, xx XX);' ' '

 這行代碼里小寫(xiě)的 xx 就是你要的屬性名,比如你的數(shù)據(jù)庫(kù)是這樣

姓名班級(jí)
張三1

其中,屬性名就是 “姓名” 和 “班級(jí)”,

小寫(xiě)的 xx 就應(yīng)該分別寫(xiě)姓名和班級(jí)(注意,不帶引號(hào))

后面的大寫(xiě)的XX就是這個(gè)屬性所接受的數(shù)據(jù)的類(lèi)型,

就相當(dāng)于Python中的 int 類(lèi)型和 str 類(lèi)型。

只不過(guò),我們?cè)?sql 語(yǔ)句中,把 int 類(lèi)型改成了 NUMBER,把 str 類(lèi)型改成了 TEXT。

當(dāng)我們運(yùn)行這個(gè)代碼,我們的文件夾目錄里會(huì)多出來(lái)一個(gè) 你的數(shù)據(jù)庫(kù)名.db 文件

當(dāng)我們?cè)俅芜\(yùn)行,會(huì)發(fā)現(xiàn)程序報(bào)錯(cuò)了。

報(bào)錯(cuò)信息的大概意思是:table 已經(jīng)存在了。

這是因?yàn)槲覀兊谝淮芜\(yùn)行時(shí)已經(jīng)創(chuàng)建了 table ,我們?cè)俅芜\(yùn)行時(shí),

程序會(huì)再次創(chuàng)建同名 table,就會(huì)報(bào)錯(cuò)。

所以,我們創(chuàng)建 table 之前要判斷一下這個(gè)table存不存在,如果存在就不創(chuàng)建,如果不存在就創(chuàng)建

這個(gè)判斷我把它寫(xiě)成了一個(gè)函數(shù),就是我上面代碼那個(gè) check 函數(shù)。

這一步也是我想了好長(zhǎng)時(shí)間,還找資料找了好長(zhǎng)時(shí)間才知道的

2.4插入數(shù)據(jù)

先放代碼

cur.executemany('INSERT INTO 你的table名 VALUES (?,?)', data)
conn.commit()

其中第一行代碼中 executemany() 函數(shù)的意思就是同時(shí)執(zhí)行多個(gè) sql 語(yǔ)句。

這個(gè)函數(shù)的括號(hào)里寫(xiě)的逗號(hào)前面就是插入數(shù)據(jù)的 sql 語(yǔ)句,后面 data 可以是一個(gè)列表或者元組。注意,如果是列表的話(huà),必須是列表里面有若干個(gè)元組的形式。

插入數(shù)據(jù)的 sql 語(yǔ)句的使用:

INSERT INTO 你的table名 VALUES (若干個(gè)逗號(hào),用逗號(hào)分割)

這里我們要插入 data 這些數(shù)據(jù),所以在括號(hào)里我們使用問(wèn)號(hào) “?” 來(lái)代替這個(gè)元素。

大家可以回去看一下 2.3 創(chuàng)建table 的講解,在2.3中,我們創(chuàng)建了兩個(gè)屬性,分別是 “姓名” 和 “班級(jí)”。因?yàn)槲覀冇袃蓚€(gè)屬性,所以要有兩個(gè)問(wèn)號(hào)。

2.5查找數(shù)據(jù)

先放代碼

def find_tb():
    cur.execute("select * from 你的table名")
    # 提取查詢(xún)到的數(shù)據(jù)
    return cur.fetchall()

這個(gè)就很簡(jiǎn)單了,我寫(xiě)這個(gè)函數(shù)使用時(shí)可以把你那個(gè)table里的所有數(shù)據(jù)都取出來(lái)。

第一行是查找table的 sql 語(yǔ)句,格式是:

select * from 你的table名

下一行再用 fetchall() 函數(shù)把數(shù)據(jù)提取出來(lái),直接 return 即可。

快樂(lè)的coding時(shí)間!

好了,前面的東西大家應(yīng)該也都看完了,來(lái)點(diǎn) demo ?

順便說(shuō)一下,我這個(gè) demo 的靈感來(lái)源是最近在網(wǎng)上刷到很多高考查分的視頻,恰好最近在做這個(gè)數(shù)據(jù)庫(kù),所以說(shuō)我這個(gè) demo 受考試的啟發(fā),就做了一個(gè)學(xué)生分?jǐn)?shù)系統(tǒng),其實(shí)這個(gè)特別爽,可以把自己的分?jǐn)?shù)改成全部滿(mǎn)分!雖然實(shí)際沒(méi)啥用,但是還是很爽的

代碼里沒(méi)有我沒(méi)講過(guò)的部分,大家可以對(duì)照上面的講解看代碼,VScode無(wú)報(bào)錯(cuò)運(yùn)行。

對(duì)了,如果有看不懂的可以私信我,不出意外的話(huà)一天之內(nèi)就能回復(fù)。

代碼:

import sqlite3
import os
def check(db_name,table_name):
    conn = sqlite3.connect(db_name)
    cursor = conn.cursor()
    sql = '''SELECT tbl_name FROM sqlite_master WHERE type = 'table' '''
    cursor.execute(sql)
    values = cursor.fetchall()
    tables = []
    for v in values:
        tables.append(v[0])
    if table_name not in tables:
        return False # 可以建表
    else:
        return True # 不能建表
def find_tb():
    cur.execute("select * from scores")
    # 提取查詢(xún)到的數(shù)據(jù)
    return cur.fetchall()
def zcd():
    os.system('cls')
    print("學(xué)生分?jǐn)?shù)管理系統(tǒng)")
    print("1.增加學(xué)生分?jǐn)?shù)信息")
    print("2.查看全部學(xué)生分?jǐn)?shù)")
    print("3.查詢(xún)分?jǐn)?shù)段內(nèi)學(xué)生分?jǐn)?shù)")
    print("4.退出")
 
if __name__ == '__main__':
    # 創(chuàng)建與數(shù)據(jù)庫(kù)的連接
    conn = sqlite3.connect('stuents_scores.db')
    #創(chuàng)建一個(gè)游標(biāo) cursor
    cur = conn.cursor()
    # 如果沒(méi)有表則執(zhí)行建表的sql語(yǔ)句
    if (check("stuents_scores.db","scores") == False):
        sql_text_1 = '''CREATE TABLE scores
                (姓名 TEXT,
                    班級(jí) TEXT,
                    性別 TEXT,
                    語(yǔ)文 NUMBER,
                    數(shù)學(xué) NUMBER,
                    英語(yǔ) NUMBER,
                    總分 NUMBER);'''
        # 執(zhí)行sql語(yǔ)句
        cur.execute(sql_text_1)
    zcd()
    while True:
        op = int(input("請(qǐng)輸入:"))
        if op == 1:
            S_name = input("請(qǐng)輸入要添加的學(xué)生的姓名(如:張三):")
            S_class = input("請(qǐng)輸入要添加的學(xué)生的班級(jí)(如:一班):")
            S_xb = input("請(qǐng)輸入該學(xué)生性別:")
            S_Chinese = int(input("請(qǐng)輸入該學(xué)生語(yǔ)文成績(jī)(只輸入一個(gè)數(shù)字,如:82):"))
            S_Maths = int(input("請(qǐng)輸入該學(xué)生數(shù)學(xué)成績(jī)(只輸入一個(gè)數(shù)字,如:95):"))
            S_English = int(input("請(qǐng)輸入該學(xué)生英語(yǔ)成績(jī)(只輸入一個(gè)數(shù)字,如:98):"))
            S_gj = S_Maths+S_Chinese+S_English # 總分
            data = [(S_name, S_class, S_xb, S_Chinese, S_Maths, S_English,S_gj)]
            cur.executemany('INSERT INTO scores VALUES (?,?,?,?,?,?,?)', data)
            conn.commit()
            # cur.close()
            # conn.close()
            print("成功!")
            os.system('pause')
            os.system('cls')
            zcd()
        elif op == 2:
            info_list = find_tb()
            print("全部學(xué)生信息(排名不分前后):")
            for i in range(len(info_list)):
                print("第"+str(i+1)+"個(gè):")
                print("學(xué)生姓名:"+str(info_list[i][0]))
                print("學(xué)生班級(jí):"+str(info_list[i][1]))
                print("學(xué)生性別:"+str(info_list[i][2]))
                print("學(xué)生語(yǔ)文成績(jī):"+str(info_list[i][3]))
                print("學(xué)生數(shù)學(xué)成績(jī):"+str(info_list[i][4]))
                print("學(xué)生英語(yǔ)成績(jī):"+str(info_list[i][5]))
                print("學(xué)生總成績(jī):"+str(info_list[i][6]))
                os.system('pause')
                os.system('cls')
                zcd()
        elif op == 3:
            info_list = find_tb()
            fen = int(input("你要要查詢(xún)總成績(jī)高于n分的學(xué)生, 請(qǐng)輸入n:"))
            for i in range(len(info_list)):
                if info_list[i][6] >= fen:
                    print("查詢(xún)結(jié)果:")
                    print("第"+str(i+1)+"個(gè):")
                    print("學(xué)生總成績(jī):"+str(info_list[i][6]))
            os.system('pause')
            os.system('cls')
            zcd()
        elif op == 4:
            os.system('cls')
            break

“Python數(shù)據(jù)庫(kù)sqlite3怎么創(chuàng)建并使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(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