Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Dapatkan Data Kamus daripada Pertanyaan SQLite?

Bagaimanakah Saya Boleh Dapatkan Data Kamus daripada Pertanyaan SQLite?

Mary-Kate Olsen
Mary-Kate Olsenasal
2025-01-04 08:29:36181semak imbas

How Can I Retrieve Dictionary Data from SQLite Queries?

Cara Mendapatkan Kamus daripada Pertanyaan SQLite

Apabila melakukan pertanyaan SQLite, anda mungkin menghadapi situasi di mana anda perlu mendapatkan data dalam format kamus sebaliknya daripada senarai. Artikel ini akan memberi anda beberapa penyelesaian untuk mencapai perkara ini.

Menggunakan row_factory

Parameter row_factory dalam sambungan SQLite membolehkan anda menentukan cara baris dikembalikan. Dengan menetapkannya kepada fungsi tersuai, anda boleh menukar tupel kepada kamus:

def dict_factory(cursor, row):
    d = {}
    for idx, col in enumerate(cursor.description):
        d[col[0]] = row[idx]
    return d

con = sqlite3.connect(":memory:")
con.row_factory = dict_factory
cur = con.cursor()
cur.execute("select 1 as a")
print(cur.fetchone()["a"])  # Output: 1

Menggunakan sqlite3.Row

Sebagai alternatif, anda boleh menetapkan row_factory kepada sqlite3.Row , yang menyediakan cara yang dioptimumkan untuk mengakses lajur oleh kedua-dua indeks dan name:

con = sqlite3.connect(...)
con.row_factory = sqlite3.Row  # Set row_factory to sqlite3.Row
cursor = con.cursor()
row = cursor.fetchone()
print(row["col1"])  # Access columns by name

Pelaksanaan Tersuai

Jika kedua-dua penyelesaian di atas tidak memenuhi keperluan anda, anda boleh membuat pelaksanaan tersuai anda sendiri. Walau bagaimanapun, pendekatan ini secara amnya tidak disyorkan kerana potensi isu prestasi berbanding dengan penyelesaian yang disediakan.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Dapatkan Data Kamus daripada Pertanyaan SQLite?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn