在 Oracle 中模拟测试 数据是非常简单的一件事情。
Oracle 首先提供了一个 dual 的虚表
其次提供了一个 Connect by 语句,实现了虚表数据列的模拟
最后 Oracle 提供了强大的 DBMS_RANDOM 包进行相关随机数的产生。
SELECT
Trunc(DBMS_RANDOM.VALUE(1,101)),
DBMS_RANDOM.string('~',5),
DBMS_RANDOM.string('l',
DBMS_RANDOM.string('L',
DBMS_RANDOM.string('a',
DBMS_RANDOM.string('A',
DBMS_RANDOM.string('u',
DBMS_RANDOM.string('U',
DBMS_RANDOM.string('x',
DBMS_RANDOM.string('X',
DBMS_RANDOM.string('p',
DBMS_RANDOM.string('P',5)
from
(
SELECT level,ROWNUM rn
FROM DUAL
CONNECT BY ROWNUM<=1001
)
CREATE TABLE RandTable
(
)
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,
CAST(RIGHT(CAST(RAND(Identiy+CAST(GETDATE() AS INT)) AS VARCHAR(100)),2) AS INT),
CAST(RIGHT(CAST(RAND(Identiy+(DATEPART(mm,GETDATE())) AS VARCHAR(100)),2) AS INT)
FROM AutoSequence
OPTION (MAXRECURSION 32767);
SELECT LEFT(NEWID(),2) AS INT)
FROM AutoSequence
OPTION (MAXRECURSION 32767);
小结:
1 、一定需要构建一种物理表
2 、 CTE 递归限制在 0 到 32,767 之间
附,经测试不需要物理表也可
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(),RAND((DATEPART(mm,RAND(Identiy+(DATEPART(mm,CAST(RIGHT(CAST(RAND(Identiy+CAST(GETDATE() AS INT)) AS VARCHAR(100)),CAST(RIGHT(CAST(RAND(Identiy+(DATEPART(mm,GETDATE())) AS VARCHAR(100)),2) AS INT) FROM AutoSequence OPTION (MAXRECURSION 32767);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。