tianfu668 2023-02-24 18:58 采纳率: 80%
浏览 44
已结题

sqlalchemy 使用查询mysql出错

在网上查了用sqlalchemy查询mysql,都提供了比较简单的方法,但是使用就报错,请大拿指导


from sqlalchemy import create_engine
engine_ts = create_engine('mysql://user:pass@127.0.0.1:3306/test?charset=utf8&use_unicode=1')
sql = 'select * from stock_basic;
df = pd.read_sql_query(sql, engine_ts)

报错数据:

File "D:\pythonProject\Trade\mysql.py", line 17, in read_data
df = pd.read_sql_query(sql, engine_ts)
File "D:\Program Files\Python38\lib\site-packages\pandas\io\sql.py", line 397, in read_sql_query
return pandas_sql.read_query(
File "D:\Program Files\Python38\lib\site-packages\pandas\io\sql.py", line 1560, in read_query
result = self.execute(args)
File "D:\Program Files\Python38\lib\site-packages\pandas\io\sql.py", line 1405, in execute
return self.connectable.execution_options().execute(args, **kwargs)
AttributeError: 'OptionEngine' object has no attribute 'execute'

  • 写回答

4条回答 默认 最新

  • tianfu668 2023-02-24 20:40
    关注

    从别的地方找到答案了,降级到2.0以下就行了,或者改脚本

    最新版本的SQLAlchemy(2.0)删除了Engine.execute。目前您可能需要降级SQLAlchemy

      python -m pip install --upgrade 'sqlalchemy<2.0'
    
    

    (or如果使用conda,则为等效的conda命令)。
    或者,正如Gord Thompson在他的评论中指出的,用sqlalchemy.text Package 查询。

    from sqlalchemy import text
    # ...
    with engine.begin() as conn:
        query = text("""SELECT * FROM tbl""")
        df = pd.read_sql_query(query, conn)
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月5日
  • 已采纳回答 2月25日
  • 修改了问题 2月24日
  • 创建了问题 2月24日

悬赏问题

  • ¥15 虚拟机打包apk出现错误
  • ¥30 最小化遗憾贪心算法上界
  • ¥15 用visual studi code完成html页面
  • ¥15 聚类分析或者python进行数据分析
  • ¥15 逻辑谓词和消解原理的运用
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝