连接的使用
说明:
使用 MySQL 的 JOIN 在两个或多个表中查询数据。
你可以在 SELECT, UPDATE 和 DELETE 语句中使用 Mysql 的 JOIN 来联合多表查询。
JOIN 大致分为三类如下:
INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
2、演示
2.1、INNER JOIN(内连接,或等值连接)
使用MySQL的INNER JOIN(也可以省略 INNER 使用 JOIN,效果一样)来连接以上两张表来读取text_table表中所有text_title字段在tcount_tbl表对应的runoob_count字段值
SELECT a.text_id, a.text_author,a.text_title FROM text_table a INNER JOIN text_table2 b ON a.text_title = b.text_title;
以上SQL表a和表b之间进行内连接,并选择a.text_id、a.text_author和a.text_title列。连接条件是a.text_title等于b.text_title。就是当a表text_title 等于 b表 text_title 返回结果
2.2、LEFT JOIN(左连接)
left join 与 join 有所不同。 MySQL LEFT JOIN 会读取左边数据表的全部数据,即使右边表无对应数据。
SELECT a.text_id, a.text_author,b.text_title FROM text_table a LEFT JOIN text_table2 b ON a.text_title = b.text_title;
以上SQL以 text_table表 为左表,text_table2表为右表
2.3、RIGHT JOIN(右连接)
RIGHT JOIN 会读取右边数据表的全部数据,即使左边边表无对应数据。
SELECT a.text_id, a.text_author,b.text_title FROM text_table a RIGHT JOIN text_table2 b ON a.text_title = b.text_title;