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

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日