Mysql自连接查询实例详解

吾爱主题 阅读:123 2024-04-05 14:22:04 评论:0

本文实例讲述了Mysql自连接查询。分享给大家供大家参考,具体如下:

自连接查询

假想以下场景:某一电商网站想要对站内产品做层级分类,一个类别下面有若干子类,子类下面也会有别的子类。例如数码产品这个类别下面有笔记本,台式机,智能手机等;笔记本,台式机,智能手机又可以按照品牌分类;品牌又可以按照价格分类,等等。也许这些分类会达到一个很深的层次,呈现一种树状的结构。那么这些数据要怎么在数据库中表示呢?我们可以在数据库中创建两个字段来存储id和类别名称,使用第三个字段存储类别的子类或者父类的id,最后通过自连接去查询想要的结果。

自连接查询其实等同于连接查询,需要两张表,只不过它的左表(父表)和右表(子表)都是自己。做自连接查询的时候,是自己和自己连接,分别给父表和子表取两个不同的别名,然后附上连接条件。看下面的例子:

1. 创建数据表:

?
1 2 3 4 5 create table tdb_cates(   id smallint primary key auto_increment,   cate_name varchar (20) not null ,   parent_id smallint not null );

注:cate_name表示分类的名称,parent_id表示父类的id。

2. 插入数据:

?
1 2 3 4 5 6 7 8 9 10 11 12 13 insert into tdb_cates(cate_name, parent_id) values ( '数码产品' , 0); insert into tdb_cates(cate_name, parent_id) values ( '家用产品' , 0); insert into tdb_cates(cate_name, parent_id) values ( '笔记本' , 1); insert into tdb_cates(cate_name, parent_id) values ( '智能手机' , 1); insert into tdb_cates(cate_name, parent_id) values ( '电器' , 2); insert into tdb_cates(cate_name, parent_id) values ( '家具' , 2); insert into tdb_cates(cate_name, parent_id) values ( '冰箱' , 5); insert into tdb_cates(cate_name, parent_id) values ( '洗衣机' , 5); insert into tdb_cates(cate_name, parent_id) values ( '汽车品牌' , 0); insert into tdb_cates(cate_name, parent_id) values ( '别克' , 9); insert into tdb_cates(cate_name, parent_id) values ( '宝马' , 9); insert into tdb_cates(cate_name, parent_id) values ( '雪佛兰' , 9); insert into tdb_cates(cate_name, parent_id) values ( '家纺' , 0);

查询结果:

3. 查询所有分类以及分类的父类:假想有左右两张表(都是tdb_cates),左表是子表,右表是父表;查询子表的id,子表的cate_name,父表的cate_name;连接条件是子表的parent_id等于父表的id。

复制代码 代码如下: select s.id, s.cate_name, p.cate_name from tdb_cates s left join tdb_cates p on s.parent_id=p.id;

 

查询结果:

4. 查询所有分类以及分类的子类:还是假想有左右两张表(都是tdb_cates),左表是子表,右表是父表;查询子表的id,子表的cate_name,父表的cate_name;连接条件是子表的id等于父表的parent_id。

复制代码 代码如下: select s.id, s.cate_name, p.cate_name from tdb_cates s left join tdb_cates p on p.parent_id=s.id;

 

查询结果:

希望本文所述对大家MySQL数据库计有所帮助。

原文链接:https://blog.csdn.net/xiaoyaoyulinger/article/details/54175483

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容