Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
b59c5144
提交
b59c5144
authored
17 年前
作者:
Thomas Mueller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
--no commit message
--no commit message
上级
ebd36602
master
noel-pr1
plus33-master
pr/267
stumc-Issue#576
version-1.1.x
version-1.4.198
version-1.4.197
version-1.4.196
version-1.4.195
version-1.4.194
version-1.4.193
version-1.4.192
version-1.4.191
version-1.4.190
version-1.4.188
version-1.4.187
version-1.4.186
version-1.4.185
version-1.4.184
version-1.4.183
version-1.4.182
version-1.4.181
version-1.4.178
version-1.4.177
version-1.3
version-1.2
version-1.1
version-1.0
无相关合并请求
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
100 行增加
和
0 行删除
+100
-0
recursiveQueries.txt
h2/src/test/org/h2/test/todo/recursiveQueries.txt
+100
-0
没有找到文件。
h2/src/test/org/h2/test/todo/recursiveQueries.txt
0 → 100644
浏览文件 @
b59c5144
WITH DirectReports (ManagerID, EmployeeID, Title, DeptID, Level)
AS
(
-- Anchor member definition
SELECT e.ManagerID, e.EmployeeID, e.Title, edh.DepartmentID,
0 AS Level
FROM Employee AS e
INNER JOIN EmployeeDepartmentHistory AS edh
ON e.EmployeeID = edh.EmployeeID AND edh.EndDate IS NULL
WHERE ManagerID IS NULL
UNION ALL
-- Recursive member definition
SELECT e.ManagerID, e.EmployeeID, e.Title, edh.DepartmentID,
Level + 1
FROM Employee AS e
INNER JOIN EmployeeDepartmentHistory AS edh
ON e.EmployeeID = edh.EmployeeID AND edh.EndDate IS NULL
INNER JOIN DirectReports AS d
ON e.ManagerID = d.EmployeeID
)
-- Statement that executes the CTE
SELECT ManagerID, EmployeeID, Title, Level
FROM DirectReports
INNER JOIN Department AS dp
ON DirectReports.DeptID = dp.DepartmentID
WHERE dp.GroupName = N'Research and Development' OR Level = 0;
GO
DROP VIEW IF EXISTS TEST_REC;
DROP VIEW IF EXISTS TEST_2;
DROP TABLE IF EXISTS TEST;
CREATE TABLE TEST(ID INT PRIMARY KEY, PARENT INT, NAME VARCHAR(255));
INSERT INTO TEST VALUES(1, NULL, 'Root');
INSERT INTO TEST VALUES(2, 1, 'Plant');
INSERT INTO TEST VALUES(3, 1, 'Animal');
INSERT INTO TEST VALUES(4, 2, 'Tree');
INSERT INTO TEST VALUES(5, 2, 'Flower');
INSERT INTO TEST VALUES(6, 3, 'Elephant');
INSERT INTO TEST VALUES(7, 3, 'Dog');
CREATE FORCE VIEW TEST_2(ID, PARENT, NAME) AS SELECT ID, PARENT, NAME FROM TEST_REC;
CREATE FORCE VIEW TEST_REC(ID, PARENT, NAME) AS
SELECT ID, PARENT, NAME FROM TEST T
WHERE PARENT IS NULL
UNION ALL
SELECT T.ID, T.PARENT, T.NAME
FROM TEST T, TEST_2 R
WHERE T.PARENT=R.ID;
SELECT * FROM TEST_REC;
------------
DROP VIEW IF EXISTS TEST_REC;
DROP VIEW IF EXISTS TEST_2;
DROP TABLE IF EXISTS TEST;
CREATE TABLE TEST(ID INT PRIMARY KEY, PARENT INT, NAME VARCHAR(255));
INSERT INTO TEST VALUES(1, NULL, 'Root');
INSERT INTO TEST VALUES(2, 1, 'Plant');
INSERT INTO TEST VALUES(3, 1, 'Animal');
INSERT INTO TEST VALUES(4, 2, 'Tree');
INSERT INTO TEST VALUES(5, 2, 'Flower');
INSERT INTO TEST VALUES(6, 3, 'Elephant');
INSERT INTO TEST VALUES(7, 3, 'Dog');
CREATE VIEW RECURSIVE TEST_REC(ID, PARENT, NAME) AS
SELECT ID, PARENT, NAME FROM TEST T
WHERE PARENT IS NULL
UNION ALL
SELECT T.ID, T.PARENT, T.NAME
FROM TEST T, TEST_REC R
WHERE T.PARENT=R.ID;
SELECT * FROM TEST_REC;
----------------
CREATE LOCAL TEMPORARY TABLE test (family_name VARCHAR_IGNORECASE(63) NOT NULL);
INSERT INTO test VALUES('Smith');
INSERT INTO test VALUES('de Smith');
INSERT INTO test VALUES('el Smith');
INSERT INTO test VALUES('von Smith');
SELECT * FROM test WHERE family_name IN ('de Smith', 'Smith');
-- okay IN(...) with TABLE_SCAN
SELECT * FROM test WHERE family_name BETWEEN 'd' AND 'T';
-- okay, ignorecase honoured
SELECT * FROM test WHERE family_name BETWEEN 'D' AND 'T';
-- okay, ignorecase honoured
CREATE INDEX family_name ON test(family_name);
SELECT * FROM test WHERE family_name IN ('de Smith', 'Smith');
-- OOPS, the comparison's operands are sorted incorrectly for ignorecase!
EXPLAIN SELECT * FROM test WHERE family_name IN ('de Smith', 'Smith');
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论