SQL相关功能实现.

网上查看行转列.差不多都是对于一个表.今天有时间自己整理下.实现一个相对通用点的.

-- =============================================
-- Author:		xin_zhou
-- Create date: 2010-03-21
-- Description:	相对通用行转列
-- =============================================
Create PROCEDURE RowToColumn 
	@tablename nvarchar(50),
	@group_value nvarchar(50),
	@coulmn_case nvarchar(50),
	@coulmn_value nvarchar(50),
	@defaultvalue nvarchar(50)=null,
	@group_fun nvarchar(10)='max'
AS
BEGIN
	declare @coulmntable table (coulmn nvarchar(50))
	declare @str_coulmntable nvarchar(120)
	declare @str_head nvarchar(60)
	declare @str_tail nvarchar(120)
	declare @str_case nvarchar(4000)
	declare @str_default nvarchar(60)
	set @str_coulmntable = 'select distinct ' + @coulmn_case + ' as coulmn from ' + @tablename
	insert into @coulmntable exec(@str_coulmntable)	
	set @str_head = 'select '+ @group_value + ' , '	
	set @str_case = ''
	if(@defaultvalue is null)
		set @str_default = ' else null end) as '
	else
		set @str_default = ' else ''' + @defaultvalue + ''' end) as '
	select @str_case = @str_case + ' ' + @group_fun + '(case '+ @coulmn_case + ' when ''' + coulmn + ''' then ' 
					+ @coulmn_value + @str_default + '''' + coulmn + ''' , ' from  @coulmntable
	set @str_case = left(@str_case,len(@str_case)-1)	
	set @str_tail = ' from ' + @tablename + ' group by ' + @group_value	
	print @str_head+@str_case+@str_tail
	exec(@str_head+@str_case+@str_tail)
END

整个就是差不多如此.参数意思大家对比下面的图就知道了.(关于参数group_value里可以输入多个栏位.用','分开,如'coulmnA,coulmnB,coulmnC')

至于为什么默认的聚合函数为max,是因为行转列应做到一对一.所以聚合函数在这本没有意义.

而别的聚合函数有的只能对int等来取.所以我首看聚合函数能用的范围大就用那个.

2.查询服务器上的所有数据库相关文件(数据文件与日志文件大小.)

主要注意的是这个本意应用游标来完成.但是心中不怎么愿意用游标.结合@@rowcount来模拟游标的实现.暂时达到目标.

declare @ch nvarchar(50)
set @ch= ''
declare @db_names table([name] nvarchar(50))
insert into @db_names(name) select name from master.dbo.sysdatabases
declare @db_file_size table(dbname nvarchar(50),datafilename nvarchar(50),datafilesize nvarchar(50),logfilename nvarchar(50),logfilesize nvarchar(50))
while @@rowcount >0
begin
	declare @dd table(name nvarchar(50),size nvarchar(50))
	select top 1 @ch=[name]  from @db_names
	insert into @dd exec('select  name,convert(varchar(50),(size/128)) as size from '+@ch+'.dbo.sysfiles')
	declare @x_name nvarchar(50)
	declare @x_size nvarchar(50)
	select @x_name=[name],@x_size=[size] from @dd where right([name],3) <> 'log' 		
	Insert into @db_file_size(dbname,datafilename,datafilesize) values(@ch,@x_name,@x_size)
	select @x_name=[name],@x_size=[size] from @dd  where right([name],3) = 'log' 
	update @db_file_size set logfilename=@x_name,logfilesize=@x_size where dbname = @ch 	
	delete @db_names where name=@ch	
end
select distinct * from @db_file_size

先写到这.

有理解错误的地方请大家指正.

 

posted @ 2010-03-23 11:26  天天不在  阅读(584)  评论(0编辑  收藏  举报