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()

 

posted @ 2024-09-20 13:08  万笑佛  阅读(10)  评论(0编辑  收藏  举报