加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 执行插入更新命令时从SQL Server搜索数据时出现TIMEOUT问

发布时间:2020-12-15 22:43:01 所属栏目:百科 来源:网络整理
导读:我有一个用C#开发的 Windows服务.此服务将XML文件中的数据导入SQL Server数据库,导入到不同的表中.这些XML文件很大. 500 MB大小的特定文件需要超过1小时才能导入到包含数百万行的表中. 我有一个在ASP.NET MVC中开发的Web应用程序,上面的数据库是在这个应用程
我有一个用C#开发的 Windows服务.此服务将XML文件中的数据导入SQL Server数据库,导入到不同的表中.这些XML文件很大. 500 MB大小的特定文件需要超过1小时才能导入到包含数百万行的表中.

我有一个在ASP.NET MVC中开发的Web应用程序,上面的数据库是在这个应用程序的后端.此应用程序通过过滤此数据库的表中的相关记录来显示不同的报告.此应用程序也操纵记录.

当我在Windows服务导入XML文件期间运行应用程序与数据库交互时,我的Web应用程序挂起,并在很长一段时间后发生超时错误.

我在Windows服务的存储过程中使用简单的插入更新命令,并且这些存储过程中没有事务.

请告知任何解决方案以避免此问题.

解决方法

根据我的经验,我可以提出一些建议.

首先,在单个事务中推送500MB的整个数据是不可取的.

然后创建必要的保存点,如果所有事务都成功,最后提交它.

因为不建议长时间保持连接对象.如果您仍然需要,可以尝试增加sql server超时.但这是一个糟糕的方法.

最好是拆分xml内容并尝试使用保存点并最终提交所有事务.

不要以为你只是做一个简单的插入或更新命令.如果列上有索引,则这些记录需要很长时间.

确保您拥有正确的索引并且只有必要的索引.

如果您有任何疑问,请在此处回复.您在当前代码中使用的方法是什么?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读