SQL SERVER批量生成编号

发表于:2017-2-24 10:17

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:ok_008    来源:51Testing软件测试网采编

#
SQL
分享:
  开始:
  在testing中,为了模拟orders,有个要求给数据库dba,如何通过后台数据库脚本快速批量生成orders。
  分析
  站在数据库角度,批量生成orders,也就是批量生成表中的行数据。
  sql中,通过cross join 可以把两个table (如 A ,B )组合,形成一个笛卡尔积,如图1
  
图1
  如果,对图1的组合结果,进行一次迭代组合,那么就可以得到一个16行的结果,如图2:
  
图2
  在sql sever 中,通过下面的sql语句分析需要A, B表组合,迭代多少次可以能生成上百万行的记录
use tempdb
go
declare @x bigint =2
declare @i int=1
while(1=1)
begin
set @x=square(@x)
if @@ERROR<>0 break;
print rtrim(@i)+' : '+rtrim(sqrt(@x))+' x '+rtrim(sqrt(@x))+' = '+rtrim(@x);
set @i+=1;
end
  从这可以看到A,B表组合,需要迭代5次就可以生成上百万行数据。
  实现:
  SQL SERVER 代码:
;With
a0 As(Select id=1 Union All Select id=1),
a1 As(Select a.id From a0 a,a0 b),
a2 As(Select a.id From a1 a,a1 b),
a3 As(Select a.id From a2 a,a2 b),
a4 As(Select a.id From a3 a,a3 b),
t  As(Select id=Row_number() Over(Order By a.id) From a4 a,a4 b)
select top 1000000 id from t
  到这里,批量生成数据行,已能实现。根据实际的需要可以附加其他的条件或数据,即可满足开头部分的需求。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号