qq_53893977 2023-03-24 11:10 采纳率: 47.6%
浏览 24
已结题

python中的sql占位符

python编程过程中sql的传参问题
如代码所示,where子句中要写一些占位符,但在运行过程中并不能事先知道要有多少个参数传进来。占位符这里应该怎么解决

cur = con.cursor(pymysql.cursors.DictCursor)
sql = 'select * from food_price where food_id in %s'
cur.execute(sql,tuple2)
print(cur.fetchall())
cur.close()
con.close()

  • 写回答

4条回答 默认 最新

  • 海洋 之心 2022年度博客之星人工智能领域TOP 1 2023-03-24 12:21
    关注
    
    # 编写SQL语句
    sql = "SELECT * FROM food_price WHERE food_id IN (%s)"
    
    # 准备参数值
    params = (value1, value2, value3)
    
    # 将占位符替换为实际的参数值
    sql_with_params = sql % ','.join(['%s'] * len(params))
    
    # 执行SQL语句
    cur.execute(sql_with_params, params)
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 4月2日
  • 已采纳回答 3月25日
  • 创建了问题 3月24日

悬赏问题

  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来