首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用python将IN子句作为变量传递给postgresql查询

如何使用python将IN子句作为变量传递给postgresql查询
EN

Stack Overflow用户
提问于 2016-06-26 03:45:03
回答 2查看 821关注 0票数 1

如何将INNOT IN子句作为变量传递给查询?

当我在查询下面传递变量时,我得到:

SELECT * FROM table_name WHERE column_name 'IN' ('product', 'category')

哪个triger出现了引号'IN'的错误?

代码语言:javascript
复制
query_clause = 'IN' 
##query_clause could equal 'NOT IN'

cur = my_connection.cursor()
cur.execute("SELECT * FROM table_name WHERE column_name %s ('product', 'category')", (query_clause,))
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-06-26 03:55:38

是的,这是意料之中的。使用布尔参数代替:

代码语言:javascript
复制
SELECT * FROM table_name
  WHERE (column_name IN ('product', 'category')) = %s

然后,可以将true或false传递到参数中。

票数 4
EN

Stack Overflow用户

发布于 2016-06-26 03:55:00

您不能为此使用sql格式字符串。只是一个普通的格式字符串

代码语言:javascript
复制
cur.execute("SELECT * FROM table_name WHERE column_name %s ('product', 'category')"%(query_clause,))

值得注意的是,假设query_clause是可信的输入.(如果这是不可信的输入,它将不会对注射进行消毒)

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38035031

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档