如何将GeoDataFrame导入MySQL?

How can I import a geoDataFrame to MySQL?(如何将GeoDataFrame导入MySQL?)
本文介绍了如何将GeoDataFrame导入MySQL?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个具有以下结构的GeoDataFrame:

<class 'geopandas.geodataframe.GeoDataFrame'>
RangeIndex: 28 entries, 0 to 27
Data columns (total 3 columns):
 #   Column       Non-Null Count  Dtype   
---  ------       --------------  -----   
 0   Name         28 non-null     object  
 1   Description  28 non-null     object  
 2   geometry     28 non-null     geometry
dtypes: geometry(1), object(2)
memory usage: 800.0+ bytes

这里有一张我的df是什么样子的图片:

我正在尝试使用gdf.to_sql将其保存在MySQL数据库中,并且我的连接使用的是SQLAlChemy,但收到以下错误:AttributeError:‘GeometryDtype’对象没有属性‘base’。

我一直在四处寻找,发现它solution,但我找不到正确的语法使其适用于MySQL。

mysql

尝试了很多方法之后,我注意到推荐答案函数没有生成正确的mysql语法使其正常工作。同样,对于更改为WKB的方法,如果我保留文本原样(请参见问题中的图片),MySQL仍然无法将该列识别为几何图形。

对我起作用的是将几何字段更改为字符串,并在python中更新它,使其看起来如下所示:

之后,我继续使用下面的代码,其中我将数据帧发送到MySQL,然后更新表以设置几何列:

regions.to_sql('pr_regions', con=conn, schema='eq_pr_db',
               if_exists='replace', index=False)

#add column type Polygon

conn.execute('''ALTER TABLE `eq_pr_db`.`pr_regions` 
                ADD COLUMN `geom` Polygon;''')

#populate new column by applying the ST_GeomFromText function to transform the string to geometry type.

conn.execute('''UPDATE `eq_pr_db`.`pr_regions`
                SET geom =  ST_GeomFromText(geometry) ;''')

这篇关于如何将GeoDataFrame导入MySQL?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)
SQL/MySQL: split a quantity value into multiple rows by date(SQL/MySQL:按日期将数量值拆分为多行)