Oracle大数据量数据生成器DataGenerator的使用.doc
文本预览下载声明
Oracle大数据量数据生成器Data Generator的使用
首先测试环境建立:dept表
CREATE TABLE dept
( deptno NUMBER(6),
dname VARCHAR2(20),
loc VARCHAR2(20));
以下实验就是像dept表中插入大量的数据。
数据生成器允许创建演示和测试数据。对于测试应用程序和查看它们怎样执行大量的数据,这很有帮助的。可以在PL/SQL Developer的工具菜单的下面找到数据生成器:Data Generator。
基本上,定义由一个或多个表、要生成的记录数量和字段数据定义构成。左上部的按钮允许打开和保存定义。
在上面,可以看到提供的 dept演示,这个演示是为 dept表创建数据。在这一页中,发现有下列项目:
?表 – 表的名称。
?记录数 – 要生成的记录数。这可以是数字,也可以是象 10..100 这样的范围。
?名称 – 字段名称。
?类型 – 字段的数据类型。
?大小 – 字段大小(在适当时)。对于数字字段,这将是数值范围、精度。
?数据 – 字段数据的定义(见下面)。
?主列 – 如果这个表是另一个表的明细,可以设置主列。对于每个已产生的记录,指定数量的明细记录将被生成。
我们可以使用“添加现有表”按钮来添加一个现有的表,还可以从对象浏览器中拖放一个表。
数据定义
数据定义决定了被生成的数据。如果要创建简单的字符,可以在两个方括号之间输入字符定义:[数据]
数据可以是下列预先确定的集的混合体:
? a: a..z (小写字符)
? A: A..Z (大写字符)
? @: A..Z 和 a..z (所有字符)
? #: A..Z 和 a..z 和 0..9 (所有字符和数字)
? *: #33..#126 (所有 ASCII 字符)
? 0: 0..9 (所有数字)
? 1: 1..9 (所有除了 0 之外的数字)
? 9: 0..9 (所有数字)
例如:
[Aaa00] 生成字符串如: Gxe21,Liy05 等。
还可以在两个单引号之间添加文字文本。
例如:
[AA - 1000] 生成字符串如:CX-4903 ,SY-1044 等。
在定义中空格字符是被忽略的,除非它们在引号中。
如果要一个字符重复许多次,可以在字符的后面两个括号之间添加次数(n)。还可以添加一个随机数(最小..最大)。
例如:
[Aa(5..15) Aa(8..20)] 的结果就象这样:Masfae Qwwecdsadif
定义中的文字文本不必被装入到括号中。换句话说,[hello] 和 hello 是等效的。不带引号被输入的文本被认为是函数。
有几个特定的函数是可用的:
?Signal(Min, Max, Delta, Noise) 返回技术测定数据(象温度这样的)。Min(最小)和 Max(最大)决定了范围, Delta(△)为最大更改量,还可以添加一些 Noise(噪声)。例如:Signal(-10, 20, 0.1, 0.1)。
?Random([Min], Max) 返回Min(最小)和 Max(最大)之间的随机数。如果只指定了 Max ,那么 Min 就被设为 0 。对于日期字段,可以输入Min(最小)和 Max(最大)的日期。
?Sequence(Start, [Inc], [WithinParent]) 返回序号。Start 为开始值,Inc 为增量(默认为 1)。对于明细表,可以再指定 WithinParent 关键词来指出序列应该为每个父记录进行重新安排。
?List(item(weight), item(weight), ...) 随机地返回指定项目(item)之一。加权数(weight)可以被添加到两个括号之间,允许特定项目比其他项目出现的几率更大。 例如:List(CLERK(50), SALESMAN(30), MANAGER(10))
?List(select statement) 象前面的 List 函数,但项目是通过 SQL select statement(select 语句)返回的。
? Text([Style], MaxCharacters, [WordsPerL
显示全部