SQL Server数字辅助表的实现
IF OBJECT_ID(N'dbo.Nums', 'U') IS NOT NULL
BEGIN
DROP TABLE dbo.Nums;
END
GO CREATE TABLE dbo.Nums
(
Num INT NOT NULL,
CONSTRAINT PK_U_CL_Nums_Num PRIMARY KEY CLUSTERED
(
Num ASC
)
);
GO INSERT INTO dbo.Nums (Num)
SELECT ROW_NUMBER() OVER (ORDER BY (SELECT NULL)) AS RowNum
FROM master.dbo.spt_values;
GO
注意:如何填充物理数字表的方法很多,为了演示作用使用了一种。
SELECT Num
FROM dbo.Nums;
GO
执行后的查询结果如下:


IF OBJECT_ID(N'dbo.ufn_GetNums', N'IF') IS NOT NULL
BEGIN
DROP TABLE dbo.ufn_GetNums;
END
GO --==================================
-- 功能: 获取指定范围的数字数列
-- 说明: 交叉最后层级的CTE得到的数据行:在L级(从0开始计数)得到的行的总数为2^^L。
-- 例如:在5级就会得到4 596行。5级的CTE提供了超过40亿的行。
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
--==================================
CREATE FUNCTION dbo.ufn_GetNums
(
@bintLow BIGINT,
@bintHigh BIGINT
) RETURNS TABLE
AS
RETURN
WITH
L0 AS (SELECT c FROM (VALUES(), ()) AS LO(c)),
L1 AS (SELECT AS c FROM L0 AS T CROSS JOIN L0 AS T2),
L2 AS (SELECT AS c FROM L1 AS T CROSS JOIN L1 AS T2),
L3 AS (SELECT AS c FROM L2 AS T CROSS JOIN L2 AS T2),
L4 AS (SELECT AS c FROM L3 AS T CROSS JOIN L3 AS T2),
L5 AS (SELECT AS c FROM L4 AS T CROSS JOIN L4 AS T2),
Nums AS (SELECT ROW_NUMBER() OVER (ORDER BY (SELECT NULL)) AS RowNum FROM L5) SELECT TOP (@bintHigh - @bintLow + ) @bintLow + RowNum - AS Num
FROM Nums
ORDER BY RowNum ASC;
GO
SQL Server 2012增加了有关分页的新特性,相关的T-SQL代码如下:
IF OBJECT_ID(N'dbo.ufn_GetNums2', N'IF') IS NOT NULL
BEGIN
DROP TABLE dbo.ufn_GetNums2;
END
GO --==================================
-- 功能: 获取指定范围的数字数列
-- 说明: 交叉最后层级的CTE得到的数据行:在L级(从0开始计数)得到的行的总数为2^^L。
-- 例如:在5级就会得到4 596行。5级的CTE提供了超过40亿的行。
-- 作者: XXX
-- 创建: yyyy-MM-dd
-- 修改: yyyy-MM-dd XXX 修改内容描述
--==================================
CREATE FUNCTION dbo.ufn_GetNums2
(
@bintLow BIGINT,
@bintHigh BIGINT
) RETURNS TABLE
AS
RETURN
WITH
L0 AS (SELECT c FROM (VALUES(), ()) AS LO(c)),
L1 AS (SELECT AS c FROM L0 AS T CROSS JOIN L0 AS T2),
L2 AS (SELECT AS c FROM L1 AS T CROSS JOIN L1 AS T2),
L3 AS (SELECT AS c FROM L2 AS T CROSS JOIN L2 AS T2),
L4 AS (SELECT AS c FROM L3 AS T CROSS JOIN L3 AS T2),
L5 AS (SELECT AS c FROM L4 AS T CROSS JOIN L4 AS T2),
Nums AS (SELECT ROW_NUMBER() OVER (ORDER BY (SELECT NULL)) AS RowNum FROM L5) SELECT @bintLow + RowNum - AS Num
FROM Nums
ORDER BY RowNum ASC
OFFSET ROWS FETCH FIRST @bintHigh - @bintLow + ROWS ONLY;
GO
以函数ufn_GetNums为例,演示相关的效果。获取指定范围的数字序列的T-SQL代码如下:
SELECT Num
FROM dbo.ufn_GetNums(, );
GO
执行后的查询结果如下:


SQL Server数字辅助表的实现的更多相关文章
- SQL虚拟数字辅助表
		虚拟数字辅助表是一个整数序列,可以用来完成多种不同的任务,如生成日期跟时间值序列,及分裂值列表.要用查询逻辑产生一个大的整数序列,可以使用交叉连接(cross join). 交叉联接(cross jo ... 
- SQL Server 怎样生成序列号(虚拟数字辅助表)
		</pre><pre name="code" class="sql">--生成一个"序列" 或者说生成一个" ... 
- SQL Server数据库、表、数据类型基本概念
		一.SQL Server的数据存储结构 SQL Server是一个数据库管理系统,需要以有效方式存储高容量数据.要更好地理解SQL Server处理数据的方式,就需要了解数据的存储结构. 1.文件类型 ... 
- SQL server 数据库用户表名称
		转自(http://blog.163.com/jlj_sk/blog/static/22579293200861422833924/) 取得SQL server 数据库中 所有用户表名称 select ... 
- 使用Spark加载数据到SQL Server列存储表
		原文地址https://devblogs.microsoft.com/azure-sql/partitioning-on-spark-fast-loading-clustered-columnstor ... 
- 在SQL SERVER中获取表中的第二条数据
		在SQL SERVER中获取表中的第二条数据, 思路:先根据时间逆排序取出前2条数据作为一个临时表,再按顺时排序在临时表中取出第一条数据 sql语句如下: select top 1 * from(se ... 
- 显示 Sql Server 中所有表或表中行的信息
		在MSSQL中显示某个数据库中所有表或视图的信息: (以下语句为获取所有表信息,将绿色字"U"替换为"V"则获取所有视图信息.) SELECT sysobjec ... 
- 快速查看SQL Server 中各表的数据量以及占用空间大小
		快速查看SQL Server 中各表的数据量以及占用空间大小. CREATE TABLE #T (NAME nvarchar(100),ROWS char(20),reserved varchar(1 ... 
- Oracle\MS SQL Server Update多表关联更新
		原文:Oracle\MS SQL Server Update多表关联更新 一条Update更新语句是不能更新多张表的,除非使用触发器隐含更新.而表的更新操作中,在很多情况下需要在表达式中引用要更新的表 ... 
随机推荐
- 软件工程day8
			设计出一份demo.上报于组,等待修改意见. 色调为黑白灰,图像也很简洁,符合“快捷查询工具”的主题. 
- objective-c(内存管理)
			本文主要记录objective-c 内存管理的知识点: 1.objective-c的对象都是分配内存在堆上,与C的mallock和C++的new类似,只有int等系统变量分配内存在栈上: 2.obje ... 
- angular ng-repeat+sortable 拖拽demo
			由于项目需求,需要使用angular 实现列表的增.删.改,并且列表支持拖拽. 看了下angular-ui 里面的sortable组件,使用起来也是非常简单,几十行代码就完成了所需功能. 我现在懒得想 ... 
- Java设计模式10:观察者模式
			观察者模式 观察者模式也叫作发布-订阅模式,也就是事件监听机制.观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,这个主题对象在状态上发生变化时,会通知所有观察者对象,使他 ... 
- Flume采集处理日志文件
			Flume简介 Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集.聚合和传输的系统,Flume支持在日志系统中定制各类数据发送方,用于收集数据:同时,Flume提供对数据 ... 
- Wix  安装部署教程(七)  获取管理员权限
			应用程序运行的时候,难免会读写文件,产生新的数据.但Program Files下的文件是不能随便更改,Win7下如果没有权限,将会被拒绝.我现在有两种方式,一种是将数据路径移到Program Data ... 
- Oracle查询DQL脚本记录
			--查询列 Select t.sname,t.ssex,t.class from student t --t 别名; Select *from student t; --* 代表查询表内所有数据 '; ... 
- 用 flow.ci 让 Hexo 持续部署
			编者按:感谢 @小小小杜 投稿,原文链接Juglans' Blog.如果你也想体验 flow.ci 的自动化持续部署,来 http://flow.ci 首页提交申请,邀请码随后会发送到邮箱:) flo ... 
- iOS-数据持久化-SQlite3
			SQLite3简单介绍 1.ios中数据的存储方式 (1)Plist(NSArray\NSDictionary) (2)Preference(偏好设置\NSUserDefaults) (3)NSCod ... 
- java 线程安全 Lock
			java.util.concurrent.locks 对于线程安全我们前面使用了synchronized关键字,对于线程的协作我们使用Object.wait()和Object.notify().在JD ... 
