WIN10 C#使用ODBC更新数据库报错

wxf54318 2018-05-04 11:48:05
数据库为Postgresql9.4
错误信息为:
[40001] ERROR: could not serialize access due to read/write dependencies among transactions;
Error while executing the query
[57014] ERROR: canceling statement due to statement timeout;
Error while executing the query

部分代码
strbuilderSql.AppendLine("BEGIN;");
foreach (String strItem in arrlItems)
{
sarrayItem = strItem.Split(',');
strbuilderSql.AppendFormat("UPDATE {0} SET \"iValue\"={1}, ", COMMONPARAMETER, Convert.ToInt32(sarrayItem[1]));
strbuilderSql.AppendFormat("\"dtUpdate\"='{0}' ", DaylightTimeTool.BaseNow.ToString(DBDefine.DATETIME_FORMAT));
strbuilderSql.AppendFormat("WHERE \"iAddress\"={0}", Convert.ToInt32(sarrayItem[0]));
strbuilderSql.AppendLine(";");
}
strbuilderSql.AppendLine("COMMIT;");
odbcCmd.CommandText = strbuilderSql.ToString();
iRecordNum = odbcCmd.ExecuteNonQuery();

...全文
454 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
wxf54318 2018-05-13
  • 打赏
  • 举报
回复
问题已解决,DELETE超时,应该用TRUNCATE
wxf54318 2018-05-13
  • 打赏
  • 举报
回复
引用 3 楼 xuzuning 的回复:
"UPDATE {0} SET \"iValue\"=...... set 子句的格式是 字段名=值 字段名怎么能加引号呢?
POSTGRESQL语法:对表名、字段名都要加双引号
wxf54318 2018-05-07
  • 打赏
  • 举报
回复
之前在postgresql 9.2版本上的程序放到9,4上会有影响吗
xuzuning 2018-05-07
  • 打赏
  • 举报
回复
"UPDATE {0} SET \"iValue\"=...... set 子句的格式是 字段名=值 字段名怎么能加引号呢?
kampoo 2018-05-04
  • 打赏
  • 举报
回复
错误提示信息翻译就是-- 在事务中有读写依赖。推断可能这一行有重复记录,也就是iAddress是不是在这个数组里重复出现了?对同一条记录在一个事务里面更新两次是不必要的(这里可能是不允许的~) 可以考虑检查数据重复性,或者设置事务隔离级别来尝试解决。
strbuilderSql.AppendFormat("WHERE \"iAddress\"={0}", Convert.ToInt32(sarrayItem[0]));
strbuilderSql.AppendLine(";");

110,534

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧