【提问文章】【已解决】 关系型数据库 公共表表达式递归查询

https://mp.csdn.net/mdeditor#

【提问文章】【已解决】关系型数据库 公共表表达式递归查询 CTE

问题原因

并不是所有数据库都支持公共表表达式的,如MySQL不同版本就不一定支持公共表表达式,更不用说公共表表达式递归查询了

我家里电脑用的是MariaDB10.3.7是支持公共表表达式的,但不支持公共表表达式递归查询,公司用的是MySQL5.7的连公共表表达式都不支持

现在已知支持公共表表达式的数据库有 Oracle 11g , mysql 8.0, sql server 2005
而且MySQL 8.0 以上的版本在需要在with后面加recursive关键字,正确的写法如下(innoDB):

//SQL语句
with recursive wingpart(subpart,qty) as 
	((select subpart,qty from components where part='wing') 
	union all 
	(select c.subpart,w.qty*c.qty from wingpart w,components c where w.subpart=c.part)) 
select sum(qty) as qty from wingpart where subpart='rivet';

问题描述

在看东南大学的一个数据库教学视频,在学到公共表表达式的时候遇到了一些问题,忘大佬指教,知道答案后也会分析出来。

问题1,是不是不同数据库不同版本不一定支持公共表表达式的?我们公司用的mysql数据库是5.6的,好像就不支持公共表表达式。

问题2,MariaDB 10.3.7是不是不支持公共表表达式递归查询? 公共表表达式能用,但在使用递归查询的时候就会报错(Table ‘university.wingpart’ doesn’t exist),是因为数据库没有保存零时表表达式的原因吗?(具体报错请看文章中的截图)

数据查询问题

查询机翼上所使用rivet的总数量

建表

//SQL语句
INSERT INTO components VALUES('wing','strut',5),('wing','aileron',1),('wing','landinggear',1),('wing','rivet',100),('strut','rivet',10),('aileron','hinge',2),('aileron','rivet',5),('landinggear','hinge',3),('landinggear','rivet',8),('hinge','rivet',4);

表格

在这里插入图片描述

查询尝试

//SQL语句
with wingpart(subpart,qty) as 
	((select subpart,qty from components where part='wing') 
	union all 
	(select c.subpart,w.qty*c.qty from wingpart w,components c where w.subpart=c.part)) 
select sum(qty) as qty from wingpart where subpart='rivet';

报错信息:
在这里插入图片描述
用的是MariaDB 10.3.7

也尝试直接在cmd中查询,也是同意的错误
在这里插入图片描述

不用递归查询没问题

//SQL语句
WITH wingpart(subpart,qty) AS ((SELECT subpart,qty FROM components WHERE part='wing')) SELECT * FROM wingpart;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值