Mysql自连接查询「建议收藏」

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

大家好,又见面了,我是你们的朋友全栈君。

自连接查询

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

1. 创建数据表:

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. 插入数据:

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);

查询结果:

Mysql自连接查询「建议收藏」

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;

查询结果:

Mysql自连接查询「建议收藏」

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://javaforall.net/132874.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月10日 上午8:36
下一篇 2022年6月10日 上午8:46


相关推荐

  • chromedriver怎么下载_chrome国内下载地址

    chromedriver怎么下载_chrome国内下载地址1、亲测能正常下载运用,具体地址如下:http://chromedriver.storage.proxy.ustclug.org/index.html选择对应版本,一定要与本地谷歌浏览器版本一致,要不在运行webdriver时会报错window10的环境,打开后选择win32的zip包应用就行,无论你是64位还是32位都选这个就ok:…

    2026年1月26日
    6
  • 高档名片设计:12款专业的名片设计欣赏

    高档名片设计:12款专业的名片设计欣赏名片作为陌生人之间建立联系的最便捷 最有效的工具 专业的名片设计可以给你的客户留下良好的第一印象 名片同时也是一个企业和个人最重要和最符合成本效益的营销工具之一 这个列表展示了 12 款专业的高档名片设计 一起欣赏 您可能感兴趣的相关文章 35 佳漂亮的迷你名片设计作品欣赏最新 70 佳很酷的名片设计作品欣赏创意无限 25 款非常酷的高档名片设计分享 35 套免费的国外 PSD 名片

    2026年3月20日
    3
  • 关于pycharm安装第三方库的一些方法

    关于pycharm安装第三方库的一些方法关于 pycharm 安装第三方库的一些方法 方法一 利用 pycharm 自带功能进行安装 以下截图来自 pycharm2018 1 4 点击 file gt nbsp gt Settings gt Projectuntit gt ProjectInter gt 点击右边加号 gt 搜索期望安装的第三方库然后点击左下角的 amp g

    2026年3月27日
    2
  • 决策树模型的参数

    决策树模型的参数决策树模型的参数 1 criteriongin 基尼系数或者熵值 2 splitterbest 前者是所有特征中最好找的切分点 后者是在部分特征中 数据量大的时候 3 max featuresNone log2 sqrt N 特征小于 50 的时候一般使用所有的 4 max depth 数据少或者特征少的时候可以不用管这个只 如果模型样本量多 特征也

    2026年3月26日
    1
  • chmod的用法_group用法与语法

    chmod的用法_group用法与语法介绍Linux中的Chmod命令用于更改或分配文件和目录的权限。在Linux/Unix系统中,文件和目录的可访问性是由文件所有权和权限决定的。在上一篇文章中,我们了解了如何使用chown命令管理文件和目录的所有权。在本教程中,我们将介绍chmod命令。chmod命令(changemode的缩写)用于管理文件和目录权限,并确定谁可以访问它们。现在让我们深入了解文件和目录权限的本质,以及如何修改它们。Linux权限文件和目录可以属于文件(u),组(g)或其他(o)的所有者u-所有人的权限g

    2022年10月20日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号