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 중국어 웹사이트의 기타 관련 기사를 참조하세요!