m0_51334054 2022-04-02 04:09 采纳率: 50%
浏览 23
已结题

.net npgsql的插入操作是不是底层报错有问题啊,总抛出主键重复

https://blog.csdn.net/m0_51334054/article/details/123911812
运行结果见链接

 string sql = "insert into department(did,dname,dinfo)values('01','数学学院','理科');";
                NpgsqlCommand SqlCommand = new NpgsqlCommand(sql, conn);
                SqlCommand.ExecuteNonQuery();

应该没什么问题吧,sql语句直接放入pgsql执行不会报错,在.net中嵌入式执行到提交步骤会抛出异常说主键重复(之前表是空的怎么可能重复啊),但确实执行了,难道一定要用trycatch把异常吞了吗
好像也不是语句中类型不匹配的问题

  • 写回答

1条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-04-02 17:25
    关注

    从这个现象上来看,是插入代码被重复执行了,你可以尝试把插入的主键字段改成一个随机数,再执行一次,看看是不是插入了多条数据

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月10日
  • 已采纳回答 4月2日
  • 创建了问题 4月2日

悬赏问题

  • ¥15 MATLAB数据处理插值
  • ¥50 husky+jaco2实现在gazebo与rviz中联合仿真
  • ¥15 dpabi预处理报错:Error using y_ExtractROISignal (line 251)
  • ¥15 在虚拟机中配置flume,无法将slave1节点的文件采集到master节点中
  • ¥15 husky+kinova jaco2 仿真
  • ¥15 zigbee终端设备入网失败
  • ¥15 金融监管系统怎么对7+4机构进行监管的
  • ¥15 硬件IIC从模式的数据发送,中断数据的接收,不能用HAL库(按照时序图)
  • ¥20 QAxWidget上显示一个word文档后,如何直接在该QAxWidget上修改和保存word文档
  • ¥15 Simulink仿真报错,请问如何解决