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()
# 编写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)
%s是个字符串啊,你把所有参数拼接好,放到括号里,不就满足这个sql的语法了吗
写个函数咯,封装个可变参数,具体实现根据实际情况来定了,可以参考下https://blog.csdn.net/X1996_/article/details/124391015