fdevilzsh 2018-12-29 16:31 采纳率: 0%
浏览 531

C# VS2008 尝试往SQLite数据库中插入 测试用MULTIPOINT类型点坐标(空间数据)失败

用C#需要在a.db数据库中的DUODIAN表的geom(MULTIPOINT)字段,插入自己随机生成的点要素,按照网上的方法添加了32位的spatialite空间扩展“libspatialite-4.dll”,已经能实现Seclect语句查询空间字段geom里的值(表里有两条样例数据,现在需要插入测试数据报错,第一次弄,请大家帮帮我,谢谢,代码如下:

```string sql="select load_extension('libspatialite-4.dll')";//引用SQLite的spatiallite扩展
SQLiteCommand comm=new SQLiteCommand();
comm.Connection=conn;
comm.CommandText=sql;
comm.ExecuteNonQuery();

comm.CommandText="insert into table_kongjian (pk,geom) values(1,GeomFromText('MULTIPOINT((2 3),(4 6))',4490))";//插入测试数据报错,
comm.ExecuteNonQuery();

错误提示:

constraint failed
table_kongjian.geom violates Geometry constraint【geom-type or SRID not allowed】

  • 写回答

1条回答 默认 最新

  • lshen01 2023-03-15 18:11
    关注

    参考GPT和自己的思路:

    首先,错误提示表明插入的数据不符合表的几何约束(Geometry constraint),可能是数据的几何类型或坐标系不符合表的要求。建议您先检查表的约束和要求,确认插入的数据符合要求。

    其次,您可以尝试使用以下代码插入测试数据:

    comm.CommandText = "insert into DUODIAN (geom) values (MakePoint(2, 3, 4490)), (MakePoint(4, 6, 4490))";
    
    comm.ExecuteNonQuery();
    

    其中,MakePoint()函数可以创建一个 POINT 或 MULTIPOINT 类型的空间对象,并指定坐标系(SRID)。

    希望这些提示能够帮助您解决问题。

    评论

报告相同问题?

悬赏问题

  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况
  • ¥15 画两个图 python或R