python关于pymysql 执行sql语句in的用法
今天在执行python代码中发现一个有意思的事,直接看代码注意如下红色部分
name = '张三' ids = 1, 2, 3 sql = " select NAME, NUM, SEX from TEMP_T WHERE NAME = %s and id in (%s)" param = (name,ids) cursor.execute(sql,param)
发现实际执行的sql语句是:
select NAME, NUM, SEX from TEMP_T WHERE NAME ='张三' and id in (1)
语句并没有按照预期的结果执行,分析发现参数param = (name,ids)多个参数就是用逗号隔开的,估计就是这里的错误,本想着把后面的参数变成一个整体应该就可以解决。尝试了元组、列表都失败,
网上还给出param = (name,(ids,))这样写就可以解决,可能是我开发环境不同这么写依然不行。
最后用了拼接字符串的方法丝滑解决,往往简单的办法最有效,直接看完整代码。
#coding=utf-8
import random
import pymysql
# 连接数据库
connection = pymysql.connect(host='192.168.0.100', user='test', password='pwd', database='testdb',port=3306)
# 操作数据库 创建一个游标
cursor = connection.cursor()
try:
#随机生成50个以 1-1000之间的整数
ids = [random.randint(1, 1000) for _ in range(50)]
# 将id列表转换为适用于SQL查询的字符串格式
ids_str = ','.join(map(str, ids))
# 随机获取100个账号
# 定义SQL查询语句,使用%s作为参数占位符
sql = " select NAME, NUM, SEX from TEMP_T WHERE NAME = %s and id in (" +ids_str +")"
name = '张三'
param = (name)
# 执行SQL查询(假设你已经建立了数据库连接和游标)
cursor.execute(sql,param)
mame = ''
num = ''
sex = ''
# 获取查询结果
rows = cursor.fetchall()
for row in rows:
mame = row[0]
num = row[1]
sex = row[2]
except pymysql.Error as e:
print(f'错误:,{e}')
cursor.close() # 关闭游标
connection.close()