query 객체에는 filter
메소드가 있다. SQL로 따지면 WHERE clause
의 역할이다. filter 메소드에 expression을 전달하면, 새로운 query 객체를 반환한다. 아래 예제는 scoped session이 적용되어 있고, TblUsers라는 ORM 클래스가 적당히 존재한다고 가정한다.
조건 결합, 추가적인 관계 연산자
query 객체의 filter
메소드에 sqlalchemy.sql
하위 함수, 또는 ORM 클래스 필드의 SQL expression 메소드를 전달하여 조건식을 결합하거나, 일반적인 관계 연산자로 표현하기 힘든 IN, BETWEEN 등의 조건식을 표현할 수 있다.
SQLAlchemy의 query 객체가 메소드 형식으로 WHERE절을 빌드하는 컨셉만 알고 있도록 하자. 나중에 필요한 쿼리가 있을 때 구글링해서 찾아보기 더 편하다.
'Python 계열 > SQLAlchemy' 카테고리의 다른 글
Engine과 Session, Scoped Session (1) | 2019.02.12 |
---|---|
union_all, literal_column (0) | 2019.02.12 |
text() (0) | 2019.02.12 |
모델 정의와 Generic Type vs SQL Standard/Multiple Vendor Type vs Vendor-Specific Type (0) | 2019.02.12 |
Column.like, Column.ilike, not_, ~expr (0) | 2019.02.12 |