@林学习 2022-01-16 16:50 采纳率: 100%
浏览 73
已结题

pymysql.execute传参字符串问题

问题遇到的现象和发生背景

使用pymysql.execute进行传参,传字符串进去,把引号也传进去了,结果就一直报错,想问一下各位大佬怎么解决?

问题相关代码,请勿粘贴截图
def find(self, condition=None, limit=0):
    sql_str = ''
    sql_str2 = ''
    if condition:
        number = 0
        sql_str += 'where '
        for i in condition.items():
            number += 1
            sql_str += 'and ' if number>1 else ''
            sql_str += f'{i[0]}={i[1]} '
    if limit:
        sql_str2 = f'limit {limit}'
    sql = 'select * from ip_agentpool %s order by score desc,speed asc %s;'
    format_list = [sql_str, sql_str2]
    influence_line = self.cur.execute(sql, format_list)
    if influence_line:                                 
        ip_agent_pool_tuple = self.cur.fetchall()
        ip_bivariate_table = pandas.DataFrame(ip_agent_pool_tuple,
        columns=['ip', 'port', 'protocol', 'anonymous', 'speed', 'area', 'score', 'disable_domains'])
        print('查询成功')
        print(ip_bivariate_table)
    else:
        print('')
运行结果及报错内容

pymysql.err.ProgrammingError: (1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''where speed=-1 ' order by score desc,speed asc 'limit 1'' at line 1")

我的解答思路和尝试过的方法

我用过字典来传参,但好像也不行

我想要达到的结果
  • 写回答

1条回答 默认 最新

  • CSDN专家-showbo 2022-01-16 17:18
    关注

    直接凭借成sql执行,要么sql中where应该放到sql语句(包含查询的列)中,查询值放入format_list 中,而不是当做查询条件传入,limit也是,sql需要动态构造

    下面是凭借成sql语句的形式

    def find(self, condition=None, limit=0):
        sql_str = ''
        sql_str2 = ''
        if condition:
            number = 0
            sql_str += 'where '
            for i in condition.items():
                number += 1
                sql_str += 'and ' if number>1 else ''
                sql_str += f'{i[0]}={i[1]} '
        if limit:
            sql_str2 = f'limit {limit}'
        sql = f'select * from ip_agentpool {sql_str} order by score desc,speed asc {sql_str2};'###########
        influence_line = self.cur.execute(sql)
        if influence_line:                                 
            ip_agent_pool_tuple = self.cur.fetchall()
            ip_bivariate_table = pandas.DataFrame(ip_agent_pool_tuple,
            columns=['ip', 'port', 'protocol', 'anonymous', 'speed', 'area', 'score', 'disable_domains'])
            print('查询成功')
            print(ip_bivariate_table)
        else:
            print('')
    
    

    参数化,sql需要拼接字段和参数%s,format_list 也需要的动态append参数值

    def find(self, condition=None, limit=0):
        sql = 'select * from ip_agentpool'
        format_list=[]
        if condition:
            number = 0
            sql += ' where '
            for i in condition.items():
                number += 1
                sql += 'and ' if number>1 else ''
                sql += f'{i[0]}=%s '
                format_list.append(i[1])###
    
        sql+=" order by score desc,speed asc "
    
        if limit:
            sql+=" limit %s";
            format_list.append(limit)###
    
        influence_line = self.cur.execute(sql, format_list)
        if influence_line:                                 
            ip_agent_pool_tuple = self.cur.fetchall()
            ip_bivariate_table = pandas.DataFrame(ip_agent_pool_tuple,
            columns=['ip', 'port', 'protocol', 'anonymous', 'speed', 'area', 'score', 'disable_domains'])
            print('查询成功')
            print(ip_bivariate_table)
        else:
            print('')
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 1月24日
  • 已采纳回答 1月16日
  • 创建了问题 1月16日

悬赏问题

  • ¥20 Keil uVision5创建project没反应
  • ¥15 mmseqs内存报错
  • ¥15 vika文档如何与obsidian同步
  • ¥15 华为手机相册里面的照片能够替换成自己想要的照片吗?
  • ¥15 陆空双模式无人机飞控设置
  • ¥15 sentaurus lithography
  • ¥100 求抖音ck号 或者提ck教程
  • ¥15 关于#linux#的问题:子进程1等待子进程A、B退出后退出(语言-c语言)
  • ¥20 web页面如何打开Outlook 365的全球离线通讯簿功能
  • ¥15 io.jsonwebtoken.security.Keys