SQLAlchemy-방언

SQLAlchemy는 방언 시스템을 사용하여 다양한 유형의 데이터베이스와 통신합니다. 각 데이터베이스에는 해당 DBAPI 래퍼가 있습니다. 모든 언어를 사용하려면 적절한 DBAPI 드라이버가 설치되어 있어야합니다.

다음 방언은 SQLAlchemy API에 포함되어 있습니다-

  • Firebird
  • 마이크로 소프트 SQL 서버
  • MySQL
  • Oracle
  • PostgreSQL
  • SQL
  • Sybase

URL을 기반으로하는 Engine 객체는 create_engine () 함수에 의해 생성됩니다. 이러한 URL에는 사용자 이름, 암호, 호스트 이름 및 데이터베이스 이름이 포함될 수 있습니다. 추가 구성을위한 선택적 키워드 인수가있을 수 있습니다. 어떤 경우에는 파일 경로가 허용되고 다른 경우에는 "데이터 소스 이름"이 "호스트"및 "데이터베이스"부분을 대체합니다. 데이터베이스 URL의 일반적인 형식은 다음과 같습니다.

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

PostgreSQL

PostgreSQL 언어는 psycopg2기본 DBAPI로. pg8000은 아래와 같이 순수 Python 대체품으로도 제공됩니다.

# 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

MySQL 방언은 mysql-python기본 DBAPI로. 다음과 같이 MySQL-connector-python과 같은 많은 MySQL DBAPI를 사용할 수 있습니다.

# 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')

신탁

Oracle 방언은 cx_oracle 다음과 같이 기본 DBAPI로-

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

마이크로 소프트 SQL 서버

SQL Server 언어는 pyodbc기본 DBAPI로. pymssql도 사용할 수 있습니다.

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

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

SQLite

SQLite는 Python 내장 모듈을 사용하여 파일 기반 데이터베이스에 연결합니다. sqlite3기본적으로. SQLite가 로컬 파일에 연결되면 URL 형식이 약간 다릅니다. URL의 "파일"부분은 데이터베이스의 파일 이름입니다. 상대 파일 경로의 경우 아래와 같이 세 개의 슬래시가 필요합니다.

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

그리고 절대 파일 경로의 경우 아래에 주어진 것처럼 세 개의 슬래시 뒤에 절대 경로가옵니다.

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

SQLite : memory : database를 사용하려면 아래와 같이 빈 URL을 지정하십시오.

engine = create_engine('sqlite://')

결론

이 자습서의 첫 번째 부분에서는 Expression Language를 사용하여 SQL 문을 실행하는 방법을 배웠습니다. 식 언어는 Python 코드에 SQL 구문을 포함합니다. 두 번째 부분에서는 SQLAlchemy의 개체 관계 매핑 기능에 대해 설명했습니다. ORM API는 SQL 테이블을 Python 클래스와 매핑합니다.