qq_38683905 2020-07-11 01:37 采纳率: 0%
浏览 942
已结题

C#利用FreeSql(Npgsql.LegacyPostgis插件驱动)操作postgis,geometry类型不存在

一、错误描述:

1、C#利用FreeSql,Npgsql.LegacyPostgis插件驱动,将实体集合(含PostgisPoint类型属性)批量插入Postgis时,有时能成功,有时报错:

The NpgsqlDbType "Geometry" isn't present in your database.You may need to install an extension or upgrade to a newer version.

var listNavaid = DBConnConfiguration.ServerFreeSql
                .Select<Fusion_Navaid>()
                .Where(t => t.CycleDate == cycleDate)
                .ToList()
                .MapTo<Fusion_Navaid, Navaid>(configure);
            DBConnConfiguration.PGFreeSql.Insert(listNavaid)
                .ExecuteAffrows();

2、查询命令也是有时成功,有时报错:

The field "Geom" has type 'public.geometry',which is currently unknown to Npgsql.You can retrieve it as a string by marking it as unknown,please see the FAQ.

var tests = DBConnConfiguration.PGFreeSql.Select<Navaid>()
                .ToList();

3、删除命令总是成功。更改命令由于不操作geometry列所以总是成功。

4、如果直接用Npgsql驱动操作Postgis ,增删改查都不会报错。

二、操作过程:

1、Navaid实体Geom属性类型为PostgisPoint,SRID=4326。Navaid表中Geom字段为geometry.point类型,SRID=4326。

2、Postgis已扩展,geodata库.public架构.Navaid表,search_path="$User",public。
Pg中关于Navaid表及Geometry列、geometry _columns视图的增删改查权限都已开启。

3、建库、扩展、建表、增加几何列、权限设置等操作在pgAdmin4和SQL Shell中都分别尝试了一次,仍然会时不时地报错。

4、连接设置。

public static string PGConnStr = 
@"User ID=postgres; Password=123456; Host=localhost; Port=5432; Database=point";

PGFreeSql = new FreeSqlBuilder()
                    .UseConnectionString(DataType.PostgreSQL, PGConnStr)
                    .UseAutoSyncStructure(true)
                    .Build();
                connTest = new NpgsqlConnection(PGConnStr);
                NpgsqlConnection.GlobalTypeMapper.UseLegacyPostgis();

5、库中有其他点类型表和线面类型的表,程序中都对其进行了增删改查操作,报相同错误。

三、环境 :

.Net Core 3.1

Postgresql 9.6

Postgis 2.3

FreeSql 1.6.0

Npgsql 4.1.3

四、目前我能想到的原因有两个,但不知道如何解决,也可能其他原因我没想到,希望大佬指点。

1、数据库关于geometry列的权限问题。

2、Npgsql.LegacyPostgis对geometry类型的映射问题。

  • 写回答

2条回答 默认 最新

  • threenewbee 2020-07-11 22:49
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog