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!