python关于pymysql 执行sql语句in的用法
今天在执行python代码中发现一个有意思的事,直接看代码注意如下红色部分
1 2 3 4 5 | 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,))这样写就可以解决,可能是我开发环境不同这么写依然不行。
最后用了拼接字符串的方法丝滑解决,往往简单的办法最有效,直接看完整代码。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | #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() |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!