>데이터 베이스 >MySQL 튜토리얼 >SQLite 쿼리에서 사전 데이터를 어떻게 검색할 수 있나요?

SQLite 쿼리에서 사전 데이터를 어떻게 검색할 수 있나요?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-04 08:29:36151검색

How Can I Retrieve Dictionary Data from SQLite Queries?

SQLite 쿼리에서 사전을 검색하는 방법

SQLite 쿼리를 수행할 때 대신 사전 형식의 데이터를 가져와야 하는 상황이 발생할 수 있습니다. 목록의. 이 문서에서는 이를 달성하기 위한 몇 가지 솔루션을 제공합니다.

row_factory 사용

SQLite 연결의 row_factory 매개변수를 사용하면 행이 반환되는 방식을 지정할 수 있습니다. 이를 사용자 정의 함수로 설정하면 튜플을 사전으로 변환할 수 있습니다.

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

sqlite3.Row 사용

또는 row_factory를 sqlite3.Row로 설정할 수 있습니다. , 이는 인덱스와 인덱스 모두를 통해 열에 액세스하는 최적화된 방법을 제공합니다. 이름:

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

사용자 정의 구현

위의 솔루션 중 어느 것도 요구 사항을 충족하지 않는 경우 사용자 정의 구현을 직접 만들 수 있습니다. 그러나 이 접근 방식은 제공된 솔루션과 비교할 때 잠재적인 성능 문제로 인해 일반적으로 권장되지 않습니다.

위 내용은 SQLite 쿼리에서 사전 데이터를 어떻게 검색할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.