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

 

posted @   万笑佛  阅读(278)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示