一、错误描述:
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类型的映射问题。