繁体   English   中英

SQL 服务器 - Python - 如何在 where 语句的元组中使用通配符 %?

[英]SQL Server - Python - How to use the wildcard % in tuple for where statement?

我正在使用 Python 和 SQL 服务器来获取具有以下规格的查询:

我要运行的原始查询(不使用元组):

SELECT *
FROM TABLE_A
WHERE COLUMN_1 LIKE '%option1%' or COLUMN_1 LIKE '%option2%'

我想创建一个包含所有选择选项的元组:

options = ('%option1%', '%option2%')

"SELECT *
FROM TABLE_A
WHERE COLUMN_1 in {options}".format(options = options)

但是,不知何故,这似乎无法正常运行。 任何人都可以帮助我提供正确的陈述吗?

使用 for 循环很容易实现:

options = ('%option1%', '%option2%')

items = ''
for option in options:
    if options.index(option) == 0: 
       items = items + " COLUMN_1 LIKE '" + option + "'"
    else: 
       items = items + " or COLUMN_1 LIKE '" + option + "'"


query = "SELECT *
         FROM TABLE_A
         WHERE {items}".format(items= items)

通过这种方式,您可以添加所需的选项数量,并且您的查询仍将以正确的方式运行。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM