<bdo id='8dyZ1'></bdo><ul id='8dyZ1'></ul>

    <tfoot id='8dyZ1'></tfoot>

    1. <i id='8dyZ1'><tr id='8dyZ1'><dt id='8dyZ1'><q id='8dyZ1'><span id='8dyZ1'><b id='8dyZ1'><form id='8dyZ1'><ins id='8dyZ1'></ins><ul id='8dyZ1'></ul><sub id='8dyZ1'></sub></form><legend id='8dyZ1'></legend><bdo id='8dyZ1'><pre id='8dyZ1'><center id='8dyZ1'></center></pre></bdo></b><th id='8dyZ1'></th></span></q></dt></tr></i><div id='8dyZ1'><tfoot id='8dyZ1'></tfoot><dl id='8dyZ1'><fieldset id='8dyZ1'></fieldset></dl></div>
      1. <legend id='8dyZ1'><style id='8dyZ1'><dir id='8dyZ1'><q id='8dyZ1'></q></dir></style></legend>

        <small id='8dyZ1'></small><noframes id='8dyZ1'>

      2. 在SQL/MySQL中,“ON"和“ON"有什么区别?和“哪里"在连接语句中?

        In SQL / MySQL, what is the difference between quot;ONquot; and quot;WHEREquot; in a join statement?(在SQL/MySQL中,“ON和“ON有什么区别?和“哪里在连接语句中?)

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

        1. <tfoot id='uN7uy'></tfoot>

              <bdo id='uN7uy'></bdo><ul id='uN7uy'></ul>
            • <legend id='uN7uy'><style id='uN7uy'><dir id='uN7uy'><q id='uN7uy'></q></dir></style></legend>

                  <i id='uN7uy'><tr id='uN7uy'><dt id='uN7uy'><q id='uN7uy'><span id='uN7uy'><b id='uN7uy'><form id='uN7uy'><ins id='uN7uy'></ins><ul id='uN7uy'></ul><sub id='uN7uy'></sub></form><legend id='uN7uy'></legend><bdo id='uN7uy'><pre id='uN7uy'><center id='uN7uy'></center></pre></bdo></b><th id='uN7uy'></th></span></q></dt></tr></i><div id='uN7uy'><tfoot id='uN7uy'></tfoot><dl id='uN7uy'><fieldset id='uN7uy'></fieldset></dl></div>
                    <tbody id='uN7uy'></tbody>
                  本文介绍了在SQL/MySQL中,“ON"和“ON"有什么区别?和“哪里"在连接语句中?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  限时送ChatGPT账号..

                  以下语句给出相同的结果(一个使用 on,另一个使用 where):

                  The following statements give the same result (one is using on, and the other using where):

                  mysql> select * from gifts INNER JOIN sentGifts ON gifts.giftID = sentGifts.giftID;
                  mysql> select * from gifts INNER JOIN sentGifts WHERE gifts.giftID = sentGifts.giftID;
                  

                  我只能在左外连接的情况下看到不匹配"的情况:
                  (找出从来没有人送过的礼物)

                  I can only see in a case of a Left Outer Join finding the "unmatched" cases:
                  (to find out the gifts that were never sent by anybody)

                  mysql> select name from gifts LEFT OUTER JOIN sentgifts 
                             ON gifts.giftID = sentgifts.giftID 
                             WHERE sentgifts.giftID IS NULL;
                  

                  在这种情况下,首先使用on,然后使用where.on 是否先进行匹配,然后 where 进行二级"过滤?或者是否有使用 onwhere 的更一般规则?谢谢.

                  In this case, it is first using on, and then where. Does the on first do the matching, and then where does the "secondary" filtering? Or is there a more general rule of using on versus where? Thanks.

                  推荐答案

                  WHERESELECT 查询整体的一部分,ON 是每个单独连接的一部分.

                  WHERE is a part of the SELECT query as a whole, ON is a part of each individual join.

                  ON 只能引用以前使用过的表的字段.

                  ON can only refer to the fields of previously used tables.

                  当左表中的记录没有实际匹配时,LEFT JOIN 从右表返回一条记录,所有字段都设置为 NULLS.WHERE 子句然后评估并过滤它.

                  When there is no actual match against a record in the left table, LEFT JOIN returns one record from the right table with all fields set to NULLS. WHERE clause then evaluates and filter this.

                  在您的查询中,只返回 gifts 中没有匹配 'sentgifts' 的记录.

                  In your query, only the records from gifts without match in 'sentgifts' are returned.

                  示例如下

                  gifts
                  
                  1   Teddy bear
                  2   Flowers
                  
                  sentgifts
                  
                  1   Alice
                  1   Bob
                  
                  ---
                  SELECT  *
                  FROM    gifts g
                  LEFT JOIN
                          sentgifts sg
                  ON      g.giftID = sg.giftID
                  
                  ---
                  
                  1  Teddy bear   1     Alice
                  1  Teddy bear   1     Bob
                  2  Flowers      NULL  NULL    -- no match in sentgifts
                  
                  ---
                  SELECT  *
                  FROM    gifts g
                  LEFT JOIN
                          sentgifts sg
                  ON      g.giftID = sg.giftID
                  WHERE   sg.giftID IS NULL
                  
                  ---
                  
                  2  Flowers      NULL  NULL    -- no match in sentgifts
                  

                  如您所见,没有实际匹配可以在 sentgifts.id 中留下 NULL,因此只会返回从未发送过的礼物.

                  As you can see, no actual match can leave a NULL in sentgifts.id, so only the gifts that had not ever been sent are returned.

                  这篇关于在SQL/MySQL中,“ON"和“ON"有什么区别?和“哪里"在连接语句中?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

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

                  相关文档推荐

                  Can#39;t Create Entity Data Model - using MySql and EF6(无法创建实体数据模型 - 使用 MySql 和 EF6)
                  MySQL select with CONCAT condition(MySQL选择与CONCAT条件)
                  Capitalize first letter of each word, in existing table(将现有表格中每个单词的首字母大写)
                  How to retrieve SQL result column value using column name in Python?(如何在 Python 中使用列名检索 SQL 结果列值?)
                  Update row with data from another row in the same table(使用同一表中另一行的数据更新行)
                  Exporting results of a Mysql query to excel?(将 Mysql 查询的结果导出到 excel?)

                      <bdo id='V5xpe'></bdo><ul id='V5xpe'></ul>
                        <tbody id='V5xpe'></tbody>

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

                      <tfoot id='V5xpe'></tfoot>
                      • <legend id='V5xpe'><style id='V5xpe'><dir id='V5xpe'><q id='V5xpe'></q></dir></style></legend>

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