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 |
先写到这.
有理解错误的地方请大家指正.
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步