Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Lulus Parameter Kamus ke Pandas `read_sql` untuk Pertanyaan SQL?

Bagaimana untuk Lulus Parameter Kamus ke Pandas `read_sql` untuk Pertanyaan SQL?

Barbara Streisand
Barbara Streisandasal
2025-01-18 07:32:08469semak imbas

How to Pass Dictionary Parameters to Pandas `read_sql` for SQL Queries?

Gunakan Panda read_sql untuk menghantar parameter untuk pertanyaan SQL

Apabila menanyakan pangkalan data daripada Pandas menggunakan SQLAlchemy, anda selalunya perlu menghantar parameter kepada pertanyaan SQL. Walaupun dokumentasi mengesyorkan menggunakan senarai parameter atau tupel, siaran ini meneroka kemungkinan menggunakan kamus.

Secara khusus, persoalannya ialah apakah sintaks yang disyorkan untuk menghantar parameter pertanyaan SQL daripada Panda menggunakan kamus.

Gunakan parameter bernama

Menurut dokumentasi read_sql, parameter boleh dihantar sebagai senarai, tuple atau kamus. Walau bagaimanapun, sintaks untuk menghantar nilai dalam pertanyaan SQL bergantung pada pemacu pangkalan data yang digunakan.

Untuk PostgreSQL menggunakan pemacu psycopg2, parameter bernama disokong menggunakan gaya %(name)s. Berikut ialah contoh:

<code class="language-python">df = psql.read_sql(('select "Timestamp", "Value" from "MyTable" '
                     'where "Timestamp" BETWEEN %(dstart)s AND %(dfinish)s'),
                   db,
                   params={"dstart": datetime(2014, 6, 24, 16, 0), "dfinish": datetime(2014, 6, 24, 17, 0)},
                   index_col=["Timestamp"])</code>

Atas ialah kandungan terperinci Bagaimana untuk Lulus Parameter Kamus ke Pandas `read_sql` untuk Pertanyaan SQL?. 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