菜单
×
   ❮   
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

PostgreSQL RIGHT JOIN


RIGHT JOIN

RIGHT JOIN 关键字选择“右表”中的所有记录,以及“左表”中的匹配记录。如果不存在匹配项,则左侧将不显示任何记录。

让我们看一个使用我们的模拟 testproducts 表的示例

 testproduct_id |      product_name      | category_id
----------------+------------------------+-------------
              1 | Johns Fruit Cake       |           3
              2 | Marys Healthy Mix      |           9
              3 | Peters Scary Stuff     |          10
              4 | Jims Secret Recipe     |          11
              5 | Elisabeths Best Apples |          12
              6 | Janes Favorite Cheese  |           4
              7 | Billys Home Made Pizza |          13
              8 | Ellas Special Salmon   |           8
              9 | Roberts Rich Spaghetti |           5
             10 | Mias Popular Ice       |          14
(10 行)

我们将尝试将 testproducts 表与 categories 表连接。

 category_id | category_name  |                       description
-------------+----------------+------------------------------------------------------------
           1 | Beverages      | Soft drinks, coffees, teas, beers, and ales
           2 | Condiments     | Sweet and savory sauces, relishes, spreads, and seasonings
           3 | Confections    | Desserts, candies, and sweet breads
           4 | Dairy Products | Cheeses
           5 | Grains/Cereals | Breads, crackers, pasta, and cereal
           6 | Meat/Poultry   | Prepared meats
           7 | Produce        | Dried fruit and bean curd
           8 | Seafood        | Seaweed and fish
(8 行)

注意:testproducts 中的许多产品都有一个 category_id,它与 categories 表中的任何类别都不匹配。

通过使用 RIGHT JOIN,我们将获得 categories 表中的所有记录,即使是那些在 testproducts 表中没有匹配项的记录。

示例

使用 category_id 列将 testproducts 连接到 categories

SELECT testproduct_id, product_name, category_name
FROM testproducts
RIGHT JOIN categories ON testproducts.category_id = categories.category_id;
运行示例 »

结果

categories 表中的所有记录,以及 testproducts 表中的匹配记录。

 testproduct_id |      product_name      | category_name
----------------+------------------------+----------------
              1 | Johns Fruit Cake       | Confections
              6 | Janes Favorite Cheese  | Dairy Products
              8 | Ellas Special Salmon   | Seafood
              9 | Roberts Rich Spaghetti | Grains/Cereals
                |                        | Condiments
                |                        | Meat/Poultry
                |                        | Beverages
                |                        | Produce
(8 行)

注意: RIGHT JOINRIGHT OUTER JOIN 的结果是相同的。

OUTERRIGHT JOIN 的默认连接类型,所以当你写 RIGHT JOIN 时,解析器实际上会写成 RIGHT OUTER JOIN


PostgreSQL 练习

通过练习来测试自己

练习

选择正确的 JOIN 子句,以选择 customers 表中的所有记录,加上 orders 表中的所有匹配记录。

SELECT * FROM orders
 customers
ON orders.customer_id = customers.customer_id;
        

开始练习


×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持