微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我有一个用C#开发的 Windows服务.此服务将XML文件中的数据导入sql Server数据库,导入到不同的表中.这些XML文件很大. 500 MB大小的特定文件需要超过1小时才能导入到包含数百万行的表中.

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

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

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

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

解决方法

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

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

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

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

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

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐