https://mp.csdn.net/mdeditor#
问题原因
并不是所有数据库都支持公共表表达式的,如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;