MySQL数据库自连接查询inner join ... on

本文介绍了SQL中的自连接查询,通过示例展示了如何在同一个表中进行数据查询,特别是针对区域表,如何查找特定省份下的所有城市。示例查询了'山东省'和'济宁市'的所有城市信息,强调了自连接查询时需对表起别名的重要性。
摘要由CSDN通过智能技术生成

1. 自连接查询

        左表和右表是同一个表,根据连接查询条件查询两个表中的数据。

区域表效果图

例1:查询省的名称为“山西省”的所有城市

创建areas表:

create table areas(
    id varchar(30) not null primary key, 
    title varchar(30), 
    pid varchar(30)
);

 执行sql文件给areas表导入数据:

source areas.sql;     【要在文件所在目录进行插入】【如source Desktop/areas.sql】

说明:

  • source 表示执行的sql文件

查看sql文件内容:

​​​​​​​

自连接查询的用法:

select c.id, c.title, c.pid, p.title from areas as c inner join areas as p on c.pid = p.id where p.title = '山东省';

 说明:

  • 自连接查询必须对表起别名
select c.id, c.title, c.pid, p.title from areas as c inner join areas as p on c.pid = p.id where p.title = '济宁市';

注意:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值