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

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)
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • 於黾 2023-03-24 11:26
    关注

    %s是个字符串啊,你把所有参数拼接好,放到括号里,不就满足这个sql的语法了吗

    评论
  • 路上走着呢 2023-03-24 12:12
    关注

    写个函数咯,封装个可变参数,具体实现根据实际情况来定了,可以参考下https://blog.csdn.net/X1996_/article/details/124391015

    评论
  • CSDN-Ada助手 CSDN-AI 官方账号 2023-03-24 14:53
    关注
    评论
查看更多回答(3条)

报告相同问题?

问题事件

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

悬赏问题

  • ¥20 用Power Query整合的问题
  • ¥20 基于python进行多背包问题的多值编码
  • ¥15 相同型号电脑与配置,发现主板有一台貌似缺少了好多元器件似的,会影响稳定性和使用寿命吗?
  • ¥15 要求编写稀疏矩阵A的转置矩阵的算法
  • ¥15 编写满足以下要求的停车场管理程序,设停车场只有一个可停放n辆车的狭窄通道且只有一个大门可供车辆进出。
  • ¥15 C语言:数据子序列基础版
  • ¥20 powerbulider 导入excel文件,显示不完整
  • ¥15 用keil调试程序保证结果进行led相关闪烁
  • ¥15 paddle训练自己的数据loss降不下去
  • ¥20 用matlab的pdetool解决以下三个问题