一、mysql常用连接
INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
mysql> select * from name_address; +----------+------+----+ address name id +----------+------+----+ 西北一路 张三 1 西北二路 李四 2 西北三路 王五 3 +----------+------+----+ 3 rows in set mysql> select * from name_age; +-----+--------+----+ age name id +-----+--------+----+ 18 张三 1 20 王五 2 21 路人甲 3 +-----+--------+----+ 3 rows in set
1、INNER JOIN
INNER JOIN与一般的连表查询一致,即使用逗号隔开的查询方式。
mysql> SELECT a.`name`,a.age,b.address FROM name_age a INNER JOIN name_address b WHERE(on) a.`name`=b.`name`; +------+-----+----------+ name age address +------+-----+----------+ 张三 18 西北一路 王五 20 西北三路 +------+-----+----------+ 2 rows in set
2、LEFT JOIN
以左边的数据表为准
mysql> SELECT a.`name`,a.age,b.address FROM name_age a left JOIN name_address b on a.`name`=b.`name`; +--------+-----+----------+ name age address +--------+-----+----------+ 张三 18 西北一路 王五 20 西北三路 路人甲 21 NULL +--------+-----+----------+ 3 rows in set
3、RIGHT JOIN
与LEFT JOIN相反,即以右边的数据为准
mysql> SELECT b.`name`,a.age,b.address FROM name_age a right JOIN name_address b on a.`name`=b.`name`; +------+------+----------+ name age address +------+------+----------+ 张三 18 西北一路 王五 20 西北三路 李四 NULL 西北二路 +------+------+----------+ 3 rows in set
相关推荐:
以上就是mysql连接查询左连接,右连接,内连接实例详解的详细内容,更多请关注php中文网其它相关文章!
……