du5591 2011-08-29 15:44
浏览 10
已采纳

加入表与另一个不匹配价值的可能性

I have 2 tables that I want to join.

      Table A
    ------------
   | owner | id |
    ------------
   |  a   |  1  |  
   |  a   |  2  |
     ..........
   |  a   |  20 |
    ------------

        Table B
    ---------------
   | a_id | number |
    ---------------
   |  1   |   2    |
   |  2   |   7    |
     .............
   |  15  |   3    |
    ---------------

How can I join those two tables, showing all of the records from Table A and ordering them by number from Table B? The total number of records in Table A and Table B is not always the same. Most of the time, Table A will have a few records (about 1 - 3) more than Table B.

I tried using a query with a WHERE clause that will check if id is equal to a_id or a_id is equal to NULL but it doesn't work. The result was, only id that exist in Table B (the a_id column) shows up.

  • 写回答

1条回答 默认 最新

  • dongna9185 2011-08-29 15:54
    关注

    Use LEFT JOIN if you want to return a row even if there is no matching row in the joined table:

    SELECT     *
    FROM       A
    LEFT JOIN  B ON B.a_id = A.id
    ORDER BY   B.number
    

    The columns of the joined table will be NULL when there was no match row.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥15 键盘指令混乱情况下的启动盘系统重装