Rumah >pembangunan bahagian belakang >Tutorial Python >Pengenalan kepada modul Psycopg2 dalam Python
Kami tahu bahawa Python ialah bahasa pengaturcaraan yang digunakan untuk melaksanakan pelbagai tugas dalam bidang seperti Analisis Data, AI, Pembelajaran Mesin dan sebagainya. Dan jelas sekali, terdapat modul berbeza dengan fungsi khas yang membantu kami melakukan kerja.
Begitu juga, kod Python berinteraksi dengan pangkalan data PostgreSQL melalui modul yang dipanggil "modul Psycopg2". Ia adalah penyesuai pangkalan data PostgreSQL yang popular untuk Python. Modul ini memberikan kami satu set fungsi dan kelas untuk membantu kami dengan sambungan pangkalan data, pemprosesan hasil dan pelaksanaan pertanyaan.
Sambungan Pangkalan Data: Modul Psycopg2 dalam Python disertakan dengan fungsi "connect()". Fungsi ini membantu mewujudkan sambungan ke pangkalan data PostgreSQL. Kami boleh menghantar parameter seperti nama pangkalan data, nama pengguna, kata laluan dan hos ke fungsi ini yang akan membantu kami menyambung ke pangkalan data pilihan kami
Pelaksanaan Pertanyaan: Modul Psycopg2 membolehkan kami memasukkan pertanyaan SQL terhadap pangkalan data PsycopgSQL yang disambungkan. Kaedah "execute()" membantu kami melaksanakan pernyataan SQL, seperti SELECT untuk mengakses data dan INSERT, UPDATE dan DELETE untuk operasi data.
Precompiled Statements: Mengoptimumkan pertanyaan SQL ialah ciri yang sangat berguna bagi modul Psycopg2. Hanya menyediakan pertanyaan SQL sekali lebih awal dan melaksanakannya beberapa kali dengan parameter yang berbeza boleh membawa kepada peningkatan besar dalam prestasi.
Pengurusan urus niaga: Psycopg2 menyediakan kami fungsi yang membantu untuk menguruskan urus niaga, melakukan perubahan dalam urus niaga dan mengembalikan segala-galanya, adalah lebih mudah dengan modul ini memastikan integriti dan konsistensi data dengan mengumpulkan beberapa operasi pangkalan data ke dalam satu unit.
Pengendalian Ralat: Psycopg2 mengendalikan ralat dan pengecualian yang berkaitan dengan pangkalan data, dan memberikan kami mesej dan maklumat ralat terperinci yang membantu kami menyahpepijat isu dengan sambungan pangkalan data atau pelaksanaan pertanyaan.
Penukaran jenis data
Pemasangan Modul Postgre2 dalam Python
pip install -U pip pip install psycopg2-binary
Cara menggunakan modul
Modul Psycopg2 mempunyai banyak aplikasi, seperti mewujudkan sambungan antara kod Python dan pangkalan data PostgreSQL Berikut ialah kod yang melakukan perkara itu:
import psycopg2 DB_NAME = "tkgafrwp" DB_USER = "tkgafrwp" DB_PASS = "iYYtLAXVbid-i6MV3NO1EnU-_9SW2uEi" DB_HOST = "tyke.db.elephantsql.com" DB_PORT = "5692" try: conn = psycopg2.connect(database=DB_NAME, user=DB_USER, password=DB_PASS, host=DB_HOST, port=DB_PORT) print("Database connected successfully") except: print("Database not connected successfully")
Di sini kita dapat melihat bahawa nama pangkalan data, pengguna pangkalan data, kata laluan, hos dan port telah disimpan dalam pembolehubah yang berbeza. Kemudian, untuk menjadikan kod itu sekukuh yang mungkin, kami menggunakan cuba dan terima blok. Di dalam blok try, kami menggunakan fungsi "connect()" untuk menyambungkan kod Python ke pangkalan data PostgreSQL. Fungsi ini menggunakan semua maklumat yang kami simpan dalam pembolehubah yang berbeza
Contoh
import psycopg2 DB_NAME = "tkgafrwp" DB_USER = "tkgafrwp" DB_PASS = "iYYtLAXVbid-i6MV3NO1EnU-_9SW2uEi" DB_HOST = "tyke.db.elephantsql.com" DB_PORT = "5692" conn = psycopg2.connect(database=DB_NAME, user=DB_USER, password=DB_PASS, host=DB_HOST, port=DB_PORT) print("Database connected successfully") cur = conn.cursor() cur.execute(""" CREATE TABLE Employee ( ID INT PRIMARY KEY NOT NULL, NAME TEXT NOT NULL, EMAI TEXT NOT NULL ) """) conn.commit() print("Table Created successfully")Di sini, kami mencipta kursor menggunakan fungsi "kursor()
Memasukkan data ke dalam jadual sedia ada juga boleh! Terdahulu kami mencipta jadual dan kemudian kami memasukkan data ke dalam jadual. Coretan kod berikut akan menunjukkan kepada kami: Contoh
import psycopg2 DB_NAME = "tkgafrwp" DB_USER = "tkgafrwp" DB_PASS = "iYYtLAXVbid-i6MV3NO1EnU-_9SW2uEi" DB_HOST = "tyke.db.elephantsql.com" DB_PORT = "5692" conn = psycopg2.connect(database=DB_NAME, user=DB_USER, password=DB_PASS, host=DB_HOST, port=DB_PORT) print("Database connected successfully") cur = conn.cursor() cur.execute(""" INSERT INTO Employee (ID, NAME, EMAIL) VALUES (1, 'Virat Kohli','viratk@gmail.com'), (2,' Lionel Messi','leomessi87@gmail.com') """) conn.commit() conn.close()
Di sini, kami menggunakan fungsi execute() untuk melaksanakan pernyataan SQL untuk memasukkan data ke dalam jadual sedia ada.
Contoh
from mysqlx import Rows import psycopg2 DB_NAME = "tkgafrwp" DB_USER = "tkgafrwp" DB_PASS = "iYYtLAXVbid-i6MV3NO1EnU-_9SW2uEi" DB_HOST = "tyke.db.elephantsql.com" DB_PORT = "5692" conn = psycopg2.connect(database=DB_NAME, user=DB_USER, password=DB_PASS, host=DB_HOST, port=DB_PORT) print("Database connected successfully") cur = conn.cursor() cur.execute("SELECT * FROM Employee") rows = cur.fetchall() for data in rows: print("ID :" + str(data[0])) print("NAME :" + data[1]) print("EMAIL :" + data[2]) print('Data fetched successfully and shown on the terminal!') conn.close()Di sini kita mempunyai baris yang diambil daripada modul "mysqlx". Kemudian, dengan menggunakan gelung for, kami mengulangi setiap baris jadual. Dengan cara ini kita mendapat semua data untuk setiap baris.
Atas ialah kandungan terperinci Pengenalan kepada modul Psycopg2 dalam Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!