sqlalchemy 에서이 쿼리를 수행하려고합니다.
SELECT id, name FROM user WHERE id IN (123, 456)
[123, 456]
실행 시간에 목록을 바인딩하고 싶습니다 .
답변
어때요?
session.query(MyUserClass).filter(MyUserClass.id.in_((123,456))).all()
편집 : ORM이 없으면
session.execute(
select(
[MyUserTable.c.id, MyUserTable.c.name],
MyUserTable.c.id.in_((123, 456))
)
).fetchall()
select()
두 개의 매개 변수를 사용합니다. 첫 번째 매개 변수는 검색 할 필드 목록이고 두 번째 매개 변수는 where
조건입니다. c
(또는 columns
) 속성을 통해 테이블 개체의 모든 필드에 액세스 할 수 있습니다 .
답변
선언적 스타일 (예 : ORM 클래스)을 사용한다고 가정하면 매우 쉽습니다.
query = db_session.query(User.id, User.name).filter(User.id.in_([123,456]))
results = query.all()
db_session
동안 데이터베이스 세션, 여기 User
와 ORM 클래스입니다 __tablename__
동일 "users"
.
답변
다른 방법은 SQLAlchemy와 함께 원시 SQL 모드를 사용하는 것입니다. SQLAlchemy 0.9.8, python 2.7, MySQL 5.X 및 MySQL-Python을 커넥터로 사용합니다.이 경우 튜플이 필요합니다. 내 코드는 다음과 같습니다.
id_list = [1, 2, 3, 4, 5] # in most case we have an integer list or set
s = text('SELECT id, content FROM myTable WHERE id IN :id_list')
conn = engine.connect() # get a mysql connection
rs = conn.execute(s, id_list=tuple(id_list)).fetchall()
모든 것이 당신을 위해 작동하기를 바랍니다.
답변
주석을 기반으로하는이 질문에서 요구하는 식 API를 사용 in_
하면 관련 열의 방법을 사용할 수 있습니다 .
쿼리하려면
SELECT id, name FROM user WHERE id in (123,456)
사용하다
myList = [123, 456]
select = sqlalchemy.sql.select([user_table.c.id, user_table.c.name], user_table.c.id.in_(myList))
result = conn.execute(select)
for row in result:
process(row)
이 것을 가정 user_table
하고 conn
적절하게 정의되어있다.
답변
파이썬 3에서 sqlalchemy와 pandas를 사용하여 솔루션을 공유하고 싶었습니다. 아마도 유용 할 것입니다.
import sqlalchemy as sa
import pandas as pd
engine = sa.create_engine("postgresql://postgres:my_password@my_host:my_port/my_db")
values = [val1,val2,val3]
query = sa.text("""
SELECT *
FROM my_table
WHERE col1 IN :values;
""")
query = query.bindparams(values=tuple(values))
df = pd.read_sql(query, engine)
답변
위의 답변에 추가하십시오.
“IN”문으로 SQL을 실행하려면 다음을 수행하십시오.
ids_list = [1,2,3]
query = "SELECT id, name FROM user WHERE id IN %s"
args = [(ids_list,)] # Don't forget the "comma", to force the tuple
conn.execute(query, args)
두 가지 점 :
- IN 문에 괄호가 필요하지 않습니다 (예 : “… IN (% s)”). “… IN % s”
- ID 목록을 튜플의 한 요소로 만듭니다. “,”를 잊지 마십시오 : (ids_list,)
편집
목록의 길이가 1 또는 0 인 경우 오류가 발생합니다.