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

自连接查询

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

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

1. 创建数据表:

create table tdb_cates( id smallint primary key auto_increment, cate_name varchar(20) not null, parent_id smallint not null);

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

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

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

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总》

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

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. 《Android和PHP最佳实践》官方站
  3. android用户界面之按钮(Button)教程实例汇
  4. Android(安卓)- Manifest 文件 详解
  5. TabHost与RadioGroup结合完成的菜单【带效果图】5个Activity
  6. Android的Handler机制详解3_Looper.looper()不会卡死主线程
  7. Android(安卓)UI开发第十七篇——Android(安卓)Fragment实例(Lis
  8. Android——Activity四种启动模式
  9. Selector、shape详解(一)

随机推荐

  1. MySQL架构:空列与联接
  2. CentOS 6.4 安装 JAVA + MYSQL + APACHE
  3. 为什么准备好的语句由每个会话管理?
  4. 程序猿(媛)Shell脚本必备技能之一: 在Lin
  5. ThinkPHP2.1 读取SqlServer数据(并解决Sql
  6. 将MySQL用于OUTFILE以生成Excel可读的UTF
  7. 如何构建一个命令来连接mySQL中的3个不同
  8. 161205、win10安装mysql5.7.16数据库
  9. PHP数据库类的封装
  10. docker mysql authentication_string cli