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

c# – 改进INSERT INTO – FROM SELECT,SQL Query

发布时间:2020-12-15 18:12:35 所属栏目:百科 来源:网络整理
导读:目前我得到了这种由程序生成的查询(c#) INSERT INTO TableName (Field1,Field2,Field3)SELECT Field1,Field3 FROM TableName2 问题是SELECT可能有许多记录的结果(如一百万),因此需要多次,结果是连接超时. 此外,如果我将所有插入分成单个插入(对于此示例,一百
目前我得到了这种由程序生成的查询(c#)
INSERT INTO TableName (Field1,Field2,Field3)
SELECT Field1,Field3 FROM TableName2

问题是SELECT可能有许多记录的结果(如一百万),因此需要多次,结果是连接超时.

此外,如果我将所有插入分成单个插入(对于此示例,一百万个插入查询),执行需要很长时间……但它有效…

有没有办法可以改进这种类型的查询?

我使用MSSQl 2005

谢谢

解决方法

我发现,如果你有很多按顺序执行的INSERT语句,你可以通过在每个xxxx数量的insert语句之后添加一个’GO’语句来提高性能:
...
INSERT INTO Table ( ... ) VALUES ( ... )
INSERT INTO Table ( ... ) VALUES ( ... )
INSERT INTO Table ( ... ) VALUES ( ... )
GO
INSERT INTO Table ( ... ) VALUES ( ... )
INSERT INTO Table ( ... ) VALUES ( ... )
...

另一种可能性是,确保您的INSERT INTO .. SELECT FROM查询不会一次性插入所有内容,而是使用某种分页技术:

INSERT INTO Table ...
SELECT ...
FROM OtherTable WHERE Id > x and Id < y

(编辑:李大同)

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

    推荐文章
      热点阅读