首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有WHERE IN的mysql-connector-python查询

带有WHERE IN的mysql-connector-python查询
EN

Stack Overflow用户
提问于 2019-12-04 20:01:51
回答 3查看 446关注 0票数 1

我正在尝试使用mysql-connector-python查询一个带有WHERE IN条件的表,如下所示:

代码语言:javascript
复制
ids = (12, 31)
cursor.execute("SELECT object_name FROM object_table WHERE object_id IN %s", ids)

我得到了以下错误:

代码语言:javascript
复制
mysql.connector.errors.ProgrammingError: Not all parameters were used in the SQL statement

我怎么才能让它工作呢?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-12-04 20:17:41

您应该将in中的"“添加为字符串,并且应将',‘替换为'%’

例如。

代码语言:javascript
复制
ids = "(12, 31)"
cursor.execute("SELECT object_name FROM object_table WHERE object_id IN %s" % ids)
票数 1
EN

Stack Overflow用户

发布于 2019-12-04 20:26:54

查询应该是字符串格式的,所以您需要将变量ids = (12, 31)包装到一个类似ids = "(12, 31)"的字符串中,并且不要忘记在传递一些值时添加%而不是,

代码语言:javascript
复制
ids = "(12, 31)"
cursor.execute("SELECT object_name FROM object_table WHERE object_id IN %s" % ids)
票数 0
EN

Stack Overflow用户

发布于 2021-02-02 15:49:32

老答案,但可能对某些人有帮助

这就是我所做的,如果ids是一个列表,在这里可能会有所帮助。

代码语言:javascript
复制
query = "UPDATE tableName SET lspaasStatus = 1 WHERE CompletedQuizId IN " + "("+str(updatedQuizids)[1:-1]+")"
mycursor.execute(query)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59175592

复制
相关文章

相似问题

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