今天在执行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()
标签:name,python,ids,param,cursor,pymysql,sql,NAME From: https://www.cnblogs.com/yclh/p/18422325