SQLAlchemy - Dialek

SQLAlchemy menggunakan sistem dialek untuk berkomunikasi dengan berbagai jenis database. Setiap database memiliki pembungkus DBAPI yang sesuai. Semua dialek mengharuskan driver DBAPI yang sesuai diinstal.

Dialek berikut termasuk dalam SQLAlchemy API -

  • Firebird
  • Microsoft SQL Server
  • MySQL
  • Oracle
  • PostgreSQL
  • SQL
  • Sybase

Objek Engine berdasarkan URL dihasilkan oleh fungsi create_engine (). URL ini dapat menyertakan nama pengguna, kata sandi, nama host, dan nama database. Mungkin ada argumen kata kunci opsional untuk konfigurasi tambahan. Dalam beberapa kasus, jalur file diterima, dan di kasus lain, "nama sumber data" menggantikan bagian "host" dan "database". Bentuk khas dari URL database adalah sebagai berikut -

dialect+driver://username:password@host:port/database

PostgreSQL

Dialek PostgreSQL menggunakan psycopg2sebagai DBAPI default. pg8000 juga tersedia sebagai pengganti Python murni seperti yang ditunjukkan di bawah ini:

# default
engine = create_engine('postgresql://scott:tiger@localhost/mydatabase')

# psycopg2
engine = create_engine('postgresql+psycopg2://scott:tiger@localhost/mydatabase')

# pg8000
engine = create_engine('postgresql+pg8000://scott:tiger@localhost/mydatabase')

MySQL

Dialek MySQL menggunakan mysql-pythonsebagai DBAPI default. Ada banyak DBAPI MySQL yang tersedia, seperti MySQL-connector-python sebagai berikut -

# default
engine = create_engine('mysql://scott:tiger@localhost/foo')

# mysql-python
engine = create_engine('mysql+mysqldb://scott:tiger@localhost/foo')

# MySQL-connector-python
engine = create_engine('mysql+mysqlconnector://scott:tiger@localhost/foo')

Peramal

Dialek Oracle menggunakan cx_oracle sebagai DBAPI default sebagai berikut -

engine = create_engine('oracle://scott:[email protected]:1521/sidname')
engine = create_engine('oracle+cx_oracle://scott:tiger@tnsname')

Microsoft SQL Server

Dialek SQL Server menggunakan pyodbcsebagai DBAPI default. pymssql juga tersedia.

# pyodbc
engine = create_engine('mssql+pyodbc://scott:tiger@mydsn')

# pymssql
engine = create_engine('mssql+pymssql://scott:tiger@hostname:port/dbname')

SQLite

SQLite terhubung ke database berbasis file, menggunakan modul built-in Python sqlite3secara default. Karena SQLite terhubung ke file lokal, format URL-nya sedikit berbeda. Bagian "file" dari URL adalah nama file dari database. Untuk jalur file relatif, ini membutuhkan tiga garis miring seperti yang ditunjukkan di bawah ini -

engine = create_engine('sqlite:///foo.db')

Dan untuk jalur file absolut, tiga garis miring diikuti oleh jalur absolut seperti yang diberikan di bawah ini -

engine = create_engine('sqlite:///C:\\path\\to\\foo.db')

Untuk menggunakan SQLite: memory: database, tentukan URL kosong seperti yang diberikan di bawah ini -

engine = create_engine('sqlite://')

Kesimpulan

Di bagian pertama tutorial ini, kita telah belajar bagaimana menggunakan Expression Language untuk mengeksekusi pernyataan SQL. Bahasa ekspresi menyematkan konstruksi SQL dalam kode Python. Pada bagian kedua, kita telah membahas kapabilitas pemetaan relasi objek dari SQLAlchemy. API ORM memetakan tabel SQL dengan kelas Python.