栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

将参数传递给DB .execute以获取WHERe IN…INT列表

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

将参数传递给DB .execute以获取WHERe IN…INT列表

编辑:请,正如@rspeer在评论中提到的那样,请务必采取预防措施以保护自己免受SQL注入攻击。

使用pg8000(与PostgreSQL数据库引擎的DB-API
2.0兼容的Pure-Python接口)进行测试:

这是将多个参数传递给“ IN”子句的推荐方法。

params = [3,2,1]stmt = 'SELECt * FROM table WHERe id IN (%s)' % ','.join('%s' for i in params)cursor.execute(stmt, params)

另一个编辑(经过充分测试且有效的示例):

>>> from pg8000 import DBAPI>>> conn = DBAPI.connect(user="a", database="d", host="localhost", password="p")>>> c = conn.cursor()>>> prms = [1,2,3]>>> stmt = 'SELECt * FROM table WHERe id IN (%s)' % ','.join('%s' for i in prms)>>> c.execute(stmt,prms)>>> c.fetchall()((1, u'myitem1'), (2, u'myitem2'), (3, u'myitem3'))


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/626652.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号