• <bdo id='RrIKc'></bdo><ul id='RrIKc'></ul>

      <small id='RrIKc'></small><noframes id='RrIKc'>

        <i id='RrIKc'><tr id='RrIKc'><dt id='RrIKc'><q id='RrIKc'><span id='RrIKc'><b id='RrIKc'><form id='RrIKc'><ins id='RrIKc'></ins><ul id='RrIKc'></ul><sub id='RrIKc'></sub></form><legend id='RrIKc'></legend><bdo id='RrIKc'><pre id='RrIKc'><center id='RrIKc'></center></pre></bdo></b><th id='RrIKc'></th></span></q></dt></tr></i><div id='RrIKc'><tfoot id='RrIKc'></tfoot><dl id='RrIKc'><fieldset id='RrIKc'></fieldset></dl></div>
      1. <legend id='RrIKc'><style id='RrIKc'><dir id='RrIKc'><q id='RrIKc'></q></dir></style></legend><tfoot id='RrIKc'></tfoot>
      2. SQL Server 插入如果不存在最佳实践

        SQL Server insert if not exists best practice(SQL Server 插入如果不存在最佳实践)
          <tbody id='Genx1'></tbody>

      3. <small id='Genx1'></small><noframes id='Genx1'>

      4. <tfoot id='Genx1'></tfoot>

        <i id='Genx1'><tr id='Genx1'><dt id='Genx1'><q id='Genx1'><span id='Genx1'><b id='Genx1'><form id='Genx1'><ins id='Genx1'></ins><ul id='Genx1'></ul><sub id='Genx1'></sub></form><legend id='Genx1'></legend><bdo id='Genx1'><pre id='Genx1'><center id='Genx1'></center></pre></bdo></b><th id='Genx1'></th></span></q></dt></tr></i><div id='Genx1'><tfoot id='Genx1'></tfoot><dl id='Genx1'><fieldset id='Genx1'></fieldset></dl></div>

          • <bdo id='Genx1'></bdo><ul id='Genx1'></ul>

              <legend id='Genx1'><style id='Genx1'><dir id='Genx1'><q id='Genx1'></q></dir></style></legend>

                  本文介绍了SQL Server 插入如果不存在最佳实践的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我有一个 Competitions 结果表,一方面保存了团队成员的姓名和他们的排名.

                  I have a Competitions results table which holds team member's names and their ranking on one hand.

                  另一方面,我需要维护一个唯一竞争对手名称的表格:

                  On the other hand I need to maintain a table of unique competitors names:

                  CREATE TABLE Competitors (cName nvarchar(64) primary key)
                  

                  现在我在第一个表中有大约 200,000 个结果,当竞争对手表为空时我可以执行此操作:

                  Now I have some 200,000 results in the 1st table and when the competitors table is empty I can perform this:

                  INSERT INTO Competitors SELECT DISTINCT Name FROM CompResults
                  

                  查询只需要 5 秒钟就可以插入大约 11,000 个名字.

                  And the query only takes some 5 seconds to insert about 11,000 names.

                  到目前为止,这不是一个关键的应用程序,因此我可以考虑每月一次截断 Competitors 表,当我收到大约 10,000 行的新比赛结果时.

                  So far this is not a critical application so I can consider truncate the Competitors table once a month, when I receive the new competition results with some 10,000 rows.

                  但是,在添加新结果以及新的和现有的竞争对手时,最佳做法是什么?我不想截断现有的竞争对手表

                  But what is the best practice when new results are added, with new AND existing competitors? I don't want to truncate existing competitors table

                  我只需要对新的竞争者执行 INSERT 语句,如果存在则什么都不做.

                  I need to perform INSERT statement for new competitors only and do nothing if they exists.

                  推荐答案

                  从语义上讲,您是在问在尚不存在的地方插入竞争对手":

                  Semantically you are asking "insert Competitors where doesn't already exist":

                  INSERT Competitors (cName)
                  SELECT DISTINCT Name
                  FROM CompResults cr
                  WHERE
                     NOT EXISTS (SELECT * FROM Competitors c
                                WHERE cr.Name = c.cName)
                  

                  这篇关于SQL Server 插入如果不存在最佳实践的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Select n random rows from SQL Server table(从 SQL Server 表中随机选择 n 行)
                  SQL query to select dates between two dates(用于选择两个日期之间的日期的 SQL 查询)
                  How can I delete using INNER JOIN with SQL Server?(如何在 SQL Server 中使用 INNER JOIN 进行删除?)
                  Table Naming Dilemma: Singular vs. Plural Names(表命名困境:单数与复数名称)
                  INSERT statement conflicted with the FOREIGN KEY constraint - SQL Server(INSERT 语句与 FOREIGN KEY 约束冲突 - SQL Server)
                  Optimal way to concatenate/aggregate strings(连接/聚合字符串的最佳方式)

                    1. <legend id='QhOaS'><style id='QhOaS'><dir id='QhOaS'><q id='QhOaS'></q></dir></style></legend>
                        • <bdo id='QhOaS'></bdo><ul id='QhOaS'></ul>

                            <i id='QhOaS'><tr id='QhOaS'><dt id='QhOaS'><q id='QhOaS'><span id='QhOaS'><b id='QhOaS'><form id='QhOaS'><ins id='QhOaS'></ins><ul id='QhOaS'></ul><sub id='QhOaS'></sub></form><legend id='QhOaS'></legend><bdo id='QhOaS'><pre id='QhOaS'><center id='QhOaS'></center></pre></bdo></b><th id='QhOaS'></th></span></q></dt></tr></i><div id='QhOaS'><tfoot id='QhOaS'></tfoot><dl id='QhOaS'><fieldset id='QhOaS'></fieldset></dl></div>
                              <tbody id='QhOaS'></tbody>
                            <tfoot id='QhOaS'></tfoot>

                            <small id='QhOaS'></small><noframes id='QhOaS'>