儛动荏笙 發表於 2023-10-14 00:00:00

让你的insert操作速度增加1000倍的方法

<p>
        很多时候方法选对了对于我们做事将会是事半功倍。<br><br>
        大家平时都会使用insert语句,特别是有时候需要一个大批量的数据来做测试,一条一条insert将会是非常慢的,那么我们如何让我们的inser更快呢。<br><br>
        先看个例子:<br><br>
        我们需要在如下这个表中插入测试数据,包含两列,一个是itemid,一个是itemname。如果向这个表中插入103,680,000 条记录,普通的插入方法可能需要20多天才能完成,但是用这里介绍的新方法在5个小时内就能够完成。</p>
<p>
        <img title="让你的insert操作速度增加1000倍的方法" alt="让你的insert操作速度增加1000倍的方法" src="https://zhuji.jb51.net/uploads/img/202305/3ce3e34452e1fcd2da6072b507fd5ebc.jpg"></p>
<p>
        先看一般的数据插入方法,假设我们向上表中插入100000 条数据:</p>
<p class="codetitle">
        <span><u>复制代码</u></span> 代码如下:</p>
<p class="codebody">
        <br>
        CREATE TABLE #tempTable( , nvarchar(30))<br>
        DECLARE @counter int<br>
        SET @counter = 1<br>
        WHILE (@counter &lt; 100000)<br>
        BEGIN<br>
        INSERT INTO #tempTable VALUES (@counter, 'Hammer')<br>
        SET @counter = @counter + 1<br>
        END<br>
        SELECT * FROM #tempTable<br>
        DROP TABLE #tempTable</p>
<p>
         </p>
<p>
         </p>
<p>
        新的插入方法会使用已经插入的数据来进行下一条记录的操作,原理如下:</p>
<p>
        <img title="让你的insert操作速度增加1000倍的方法" alt="让你的insert操作速度增加1000倍的方法" src="https://zhuji.jb51.net/uploads/img/202305/1483465728b2b4c1c2be6114429b4e3f.jpg"></p>
<p>
         那么看看我的新insert代码:</p>
<p class="codetitle">
        <span><u>复制代码</u></span> 代码如下:</p>
<p class="codebody">
        <br>
        CREATE TABLE #tempTable( , nvarchar(30))<br>
        INSERT INTO #tempTable VALUES (1, 'Hammer')<br>
        WHILE((SELECT COUNT(*) FROM #tempTable) &lt; 100000)<br>
        BEGIN<br>
        INSERT INTO #tempTable (, )<br>
        (SELECT + (SELECT COUNT(*) FROM #tempTable), 'Hammer' FROM #tempTable)<br>
        END<br>
        SELECT * FROM #tempTable<br>
        DROP TABLE #tempTable</p>
<p>
        <br>
        用第一种方法可能需要几十分钟插入100000数据,但是用第二种只要4秒钟。再改进下,2秒钟就完成:</p>
<p class="codetitle">
        <span><u>复制代码</u></span> 代码如下:</p>
<p class="codebody">
        <br>
        CREATE TABLE #tempTable( , nvarchar(30))<br>
        INSERT INTO #tempTable VALUES (1, 'Hammer')<br>
        DECLARE @counter int<br>
        SET @counter = 1<br>
        WHILE(@counter &lt;= 17)<br>
        BEGIN<br>
        INSERT INTO #tempTable (, )<br>
        (SELECT + (SELECT COUNT(*) FROM #tempTable), 'Hammer' FROM #tempTable)<br>
        SET @counter = @counter + 1<br>
        END<br>
        SELECT * FROM #tempTable<br>
        DROP TABLE #tempTable</p>
<p>
         </p>
頁: [1]
查看完整版本: 让你的insert操作速度增加1000倍的方法