SQLAlchemy Core-조인 사용

이 장에서는 SQLAlchemy에서 조인을 사용하는 방법을 배웁니다.

조인의 효과는 두 개의 테이블을 columns clause 아니면 그 where clauseselect () 구조의. 이제 join () 및 outerjoin () 메서드를 사용합니다.

join () 메서드는 한 테이블 객체에서 다른 테이블 객체로 결합 객체를 반환합니다.

join(right, onclause = None, isouter = False, full = False)

위 코드에서 언급 한 매개 변수의 기능은 다음과 같습니다.

  • right-조인의 오른쪽; 이것은 모든 Table 객체입니다.

  • onclause− 조인의 ON 절을 나타내는 SQL 표현식. None으로두면 외래 키 관계를 기반으로 두 테이블을 조인합니다.

  • isouter − True이면 JOIN 대신 LEFT OUTER JOIN을 렌더링합니다.

  • full − True이면 LEFT OUTER JOIN 대신 FULL OUTER JOIN을 렌더링합니다.

예를 들어 다음과 같이 join () 메서드를 사용하면 외래 키를 기준으로 자동으로 조인됩니다.

>>> print(students.join(addresses))

이것은 다음 SQL 표현식과 동일합니다-

students JOIN addresses ON students.id = addresses.st_id

다음과 같이 결합 기준을 명시 적으로 언급 할 수 있습니다.

j = students.join(addresses, students.c.id == addresses.c.st_id)

이제이 조인을 사용하여 아래 선택 구조를 작성하면-

stmt = select([students]).select_from(j)

이것은 다음과 같은 SQL 표현식을 초래합니다-

SELECT students.id, students.name, students.lastname
FROM students JOIN addresses ON students.id = addresses.st_id

엔진을 나타내는 연결을 사용하여이 문을 실행하면 선택한 컬럼에 속한 데이터가 표시됩니다. 완전한 코드는 다음과 같습니다.

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, ForeignKey
engine = create_engine('sqlite:///college.db', echo = True)

meta = MetaData()
conn = engine.connect()
students = Table(
   'students', meta, 
   Column('id', Integer, primary_key = True), 
   Column('name', String), 
   Column('lastname', String), 
)

addresses = Table(
   'addresses', meta, 
   Column('id', Integer, primary_key = True), 
   Column('st_id', Integer,ForeignKey('students.id')), 
   Column('postal_add', String), 
   Column('email_add', String)
)

from sqlalchemy import join
from sqlalchemy.sql import select
j = students.join(addresses, students.c.id == addresses.c.st_id)
stmt = select([students]).select_from(j)
result = conn.execute(stmt)
result.fetchall()

다음은 위 코드의 출력입니다.

[
   (1, 'Ravi', 'Kapoor'),
   (1, 'Ravi', 'Kapoor'),
   (3, 'Komal', 'Bhandari'),
   (5, 'Priya', 'Rajhans'),
   (2, 'Rajiv', 'Khanna')
]