关于SQLServer2005的学习笔记——CTE递归和模拟测试数据
来源:互联网 发布:网络教育本科考试难吗 编辑:程序博客网 时间:2024/06/05 02:55
在Oracle中模拟测试数据是非常简单的一件事情。
Oracle首先提供了一个dual的虚表
其次提供了一个Connect by语句,实现了虚表数据列的模拟
最后Oracle提供了强大的DBMS_RANDOM包进行相关随机数的产生。
SELECT
TRUNC(DBMS_RANDOM.VALUE(1,101)),
DBMS_RANDOM.string('~',5),
DBMS_RANDOM.string('l',5),
DBMS_RANDOM.string('L',5),
DBMS_RANDOM.string('a',5),
DBMS_RANDOM.string('A',5),
DBMS_RANDOM.string('u',5),
DBMS_RANDOM.string('U',5),
DBMS_RANDOM.string('x',5),
DBMS_RANDOM.string('X',5),
DBMS_RANDOM.string('p',5),
DBMS_RANDOM.string('P',5)
from
(
SELECT level,ROWNUM rn
FROM DUAL
CONNECT BY ROWNUM<=1001
)
相比而言,SQLServer则没那么幸运了,首先没有虚拟的概念,则需要构建一个物理表以存储需要模拟的次数,再次需要使用CTE递归来模拟一个虚表数据,最后才通过相关随机函数进行构建数据。
--创建一个物理表,并插入要模拟的次数,最大不能超过32767
CREATE TABLE RandTable
(
MaxNumber INT CHECK (MaxNumber >= 0 AND MaxNumber<=32767),
)
INSERT INTO RandTable values(32767);
--使用CTE递归构建列数据
WITH AutoSequence(MaxNumber,Identiy)
AS
(
SELECT e.MaxNumber,1 AS Identiy FROM RandTable AS e
UNION ALL
SELECT e.MaxNumber,Identiy+1 c FROM RandTable AS e,AutoSequence d
WHERE d.Identiy<e.MaxNumber AND d.Identiy<500
)
--用时间+递增值做种子进行RAND
SELECT LEFT(NEWID(),4),
RAND((DATEPART(mm,GETDATE())*100000)+(DATEPART(ss,GETDATE())*1000)+DATEPART(ms,GETDATE())),
RAND(Identiy+(DATEPART(mm,GETDATE())*100000)+(DATEPART(ss,GETDATE())*1000)+DATEPART(ms,GETDATE())),
CAST(RIGHT(CAST(RAND(Identiy+CAST(GETDATE() AS INT)) AS VARCHAR(100)),2) AS INT),
CAST(RIGHT(CAST(RAND(Identiy+(DATEPART(mm,GETDATE())*100000)+(DATEPART(ss,GETDATE())*1000)+DATEPART(ms,GETDATE())) AS VARCHAR(100)),2) AS INT)
FROM AutoSequence
OPTION (MAXRECURSION 32767);
SELECT LEFT(NEWID(),4),
CAST(RIGHT(CAST(RAND(Identiy+CAST(GETDATE() AS INT)) AS VARCHAR(100)),2) AS INT)
FROM AutoSequence
OPTION (MAXRECURSION 32767);
小结:
使用CTE递归和SQLServer随机函数还是存在很多问题的。
1、一定需要构建一种物理表
2、CTE递归限制在0到32,767之间
3、RAND产生的随机数比较集中,通过时间+递增值的方式来实现的话,只能截取后几位,导致无法控制随机值的区域。
4、NEWID()产生的随机数为字符和数字混杂,也不能得到预期的效果
附,经测试不需要物理表也可
WITH RandTable(MaxNumber)
AS
(
SELECT 500 MaxNumber
),
AutoSequence(MaxNumber,Identiy)
AS
(
SELECT e.MaxNumber,1 AS Identiy FROM RandTable AS e
UNION ALL
SELECT e.MaxNumber,Identiy+1 c FROM RandTable AS e,AutoSequence d
WHERE d.Identiy<e.MaxNumber AND d.Identiy<500
)
SELECT LEFT(NEWID(),4),
RAND((DATEPART(mm,GETDATE())*100000)+(DATEPART(ss,GETDATE())*1000)+DATEPART(ms,GETDATE())),
RAND(Identiy+(DATEPART(mm,GETDATE())*100000)+(DATEPART(ss,GETDATE())*1000)+DATEPART(ms,GETDATE())),
CAST(RIGHT(CAST(RAND(Identiy+CAST(GETDATE() AS INT)) AS VARCHAR(100)),2) AS INT),
CAST(RIGHT(CAST(RAND(Identiy+(DATEPART(mm,GETDATE())*100000)+(DATEPART(ss,GETDATE())*1000)+DATEPART(ms,GETDATE())) AS VARCHAR(100)),2) AS INT)
FROM AutoSequence
OPTION (MAXRECURSION 32767);
- 关于SQLServer2005的学习笔记——CTE递归和模拟测试数据
- 关于SQLServer2005的学习笔记——临时表、表变量和CTE
- 关于SQLServer2005的学习笔记——XML的处理
- 关于SQLServer2005的学习笔记——XML的处理
- 关于SQLServer2005的学习笔记——XML的处理
- 关于SQLServer2005的学习笔记——XML的处理
- 关于SQLServer2005的学习笔记(一)——前言
- 关于SQLServer2005 的学习笔记(一)——前言
- 关于SQLServer2005的学习笔记——子查询
- 关于SQLServer2005的学习笔记——分析函数
- 关于SQLServer2005的学习笔记——树形结构问题
- 关于SQLServer2005的学习笔记——生日问题
- 关于SQLServer2005的学习笔记——生日问题
- 关于SQLServer2005的学习笔记——系统触发器
- SQLServer2005中的CTE递归查询得到一棵树
- 关于SQLServer2005的学习笔记——约束、Check、触发器的执行顺序
- 关于SQLServer2005的学习笔记——约束、Check、触发器的执行顺序
- 关于SQLServer2005的学习笔记——自定义分组的实现
- PreTranslateMessage作用和使用方法
- Google搜索 入门 1
- 百度为什么打不开!最新消息~
- http错误代码含义
- struts1工作流程
- 关于SQLServer2005的学习笔记——CTE递归和模拟测试数据
- DK1.6官方下载_JDK6官方下载
- ORACLE ROWID的一点知识
- ServletContextListener
- 关于.net托管环境下struct类型的内存布局的认识
- (转载)GNU 工具链视频
- xorg.conf
- Tapestry技术交流群,欢迎广大Tapestry爱好者加入!群号:72088142
- SQLite数据类型