经常做数据库访问性能测试时,需要用到数据量很大的表,自己动手写一段TSQL语句即可。 TSQL_生成表结构: /**//****** 对象: 表 [dbo].[LargeTable] 脚本日期: 2006-10-26 15:40:27 ******/ ALTER TABLE [dbo].[LargeTable] WITH NOCHECK ADD ALTER TABLE [dbo].[LargeTable] ADD /**//*truncate table largetable*/ declare @title nvarchar(100) declare @randtime_month tinyint declare @str varchar(30) print 开始执行时间: + cast(getdate() as varchar) insert into largetable values(@title,@content,@publictime,@author,@istop) http://www.cnblogs.com/jiny-z/archive/2006/10/26/540801.html
/**//****** 对象: 表 [dbo].[LargeTable] 脚本日期: 2006-10-26 15:40:27 ******/
if exists (select * from dbo.sysobjects where id = object_id(N[dbo].[LargeTable]) and OBJECTPROPERTY(id, NIsUserTable) = 1)
drop table [dbo].[LargeTable]
GO
CREATE TABLE [dbo].[LargeTable] (
[ID] [int] IDENTITY (1, 1) NOT NULL ,
[Title] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NULL ,
[Content] [ntext] COLLATE Chinese_PRC_CI_AS NULL ,
[PublicTime] [datetime] NULL ,
[Author] [nvarchar] (10) COLLATE Chinese_PRC_CI_AS NULL ,
[IsTop] [tinyint] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO
CONSTRAINT [PK_LargeTable] PRIMARY KEY CLUSTERED
(
[ID]
) ON [PRIMARY]
GO
CONSTRAINT [DF_LargeTable_IsTop] DEFAULT (0) FOR [IsTop]
GO
exec sp_addextendedproperty NMS_Description, N作者, Nuser, Ndbo, Ntable, NLargeTable, Ncolumn, NAuthor
GO
exec sp_addextendedproperty NMS_Description, N内容, Nuser, Ndbo, Ntable, NLargeTable, Ncolumn, NContent
GO
exec sp_addextendedproperty NMS_Description, N文章表,包含100万条记录, Nuser, Ndbo, Ntable, NLargeTable, Ncolumn, NID
GO
exec sp_addextendedproperty NMS_Description, N是否置顶 0.不置顶 1.置顶, Nuser, Ndbo, Ntable, NLargeTable, Ncolumn, NIsTop
GO
exec sp_addextendedproperty NMS_Description, N发布时间, Nuser, Ndbo, Ntable, NLargeTable, Ncolumn, NPublicTime
GO
exec sp_addextendedproperty NMS_Description, N文章标题, Nuser, Ndbo, Ntable, NLargeTable, Ncolumn, NTitle
GO
TSQL_生成表数据:
declare @content nvarchar(100)
declare @publictime datetime
declare @author nvarchar(10)
declare @istop tinyint
declare @randtime_day tinyint
declare @randtime_hour tinyint
declare @randtime_minute tinyint
declare @randtime_second tinyint
declare @i int,@count int
set @i=1
set @count=500000
while @i<=@count
begin
set @randtime_month=rand(@i)*12
set @randtime_day=rand(@i)*28
set @randtime_hour=rand(@i)*24
set @randtime_minute=rand(@i)*60
set @randtime_second=rand(@i)*60
set @str=2006-+cast(@randtime_month as varchar)+-+cast(@randtime_day as varchar)+ +cast(@randtime_hour as varchar)+:+cast(@randtime_minute as varchar)+:+cast(@randtime_second as varchar)
set @title=文章标题+cast(@i as varchar)
set @content=文章内容+cast(@i as varchar)
set @publictime=convert(datetime,@str,120)
set @author=作者+cast(@i as varchar)
if @i%10000=0
set @istop=1
else
set @istop=0
set @i=@i+1
end
print 执行完毕时间: + cast(getdate() as varchar)
生成50万条记录的大数据表的tsql语句_数据库技巧
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 生成50万条记录的大数据表的tsql语句_数据库技巧
相关推荐
-      sql语句中的判断功能的使用方法
-      sql语句中的判断功能的使用方法
-      SQL语言中去掉小数点有效数字后面的所有0
-      在sql语句中实现md5功能
-      ASP连接各种数据库的代码
-      给access数据库减肥
-      asp连接access数据库代码(2)
-      更改 SQL Server 登录模式