gpt4 book ai didi

python - 如何将Python字符串列表传递给sql查询

转载 作者:太空宇宙 更新时间:2023-11-03 20:24:53 24 4
gpt4 key购买 nike

如何将 python 字符串列表传递给 SQL 查询,例如 select * from table where name in (names_from_python_list) 其中 names_from_python_list 是来自 python 列表的逗号分隔字符串?

执行 ','.join(name for name in name_list) 会将列表中的所有名称作为字符串给出,即

 select * from table where name in ('john,james,mary')

然而,我想做的是:

  select * from table where name in ('john','james','mary')

最佳答案

我建议不要重新发明轮子,而是查看成熟数据库库提供的 native 解决方案。

psqycopg2 例如允许注册适配器,以便处理列表(和其他序列)变得透明,您可以直接将列表作为查询参数传递。这是一个示例:https://chistera.yi.org/~dato/blog/entries/2009/03/07/psycopg2_sql_in.html

pymysql 还提供了一组很好的内置转义器,其中包括一个用于处理序列的转义器,这样您就不必担心手动格式化(这很容易出错),并且可以直接使用元组作为 IN 子句中的参数。示例:

>>> conn = pymysql.connect(host='localhost', user='root', password='root', db='test')
>>> c.execute('select * from hosts where ip in %s', (('ip1', 'ip2'),))
>>> c.fetchall()
((1, 'mac1', 'ip1'), (3, None, 'ip2'))

很确定许多其他成熟的库/框架提供类似的功能。

关于python - 如何将Python字符串列表传递给sql查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57910021/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com