一、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衔接查询中索引的重要性
mysql衔接查询典范小例题_MySQL
典范mysql衔接查询例题_MySQL
以上就是mysql衔接查询左衔接,右衔接,内衔接实例详解的细致内容,更多请关注ki4网别的相干文章!