--SQLSERVER查詢單個資料表所有欄位名組合成的字串指令碼
--應用場合: 用於產生SQL查詢字串中select 欄位名列表1 from table group by 欄位名列表2 中的欄位名列表1和欄位名列表2部分
--定義資料表名稱變數
Declare @TableName nvarchar(250)
Set @TableName='您的資料表名稱' --這裡修改成您要查詢的資料表名稱
--定義列總數變數
Declare @TotalColumns int
Select @TotalColumns=count(name) from syscolumns Where ID=OBJECT_ID(@TableName)
print '資料表'+@TableName+'欄位總數為:'+Convert(nvarchar(20),@TotalColumns)
--定義所有欄位名稱字串變數
Declare @ColumnsString nvarchar(4000)
set @ColumnsString=''
--定義遊標中輸出的欄位名變數
Declare @ColumnName nvarchar(255)
--通過遊標讀取指定資料表的所有欄位
--聲明遊標mycursor
declare mycursor cursor for select name from syscolumns Where ID=OBJECT_ID(@TableName) order by colid
--開啟遊標
open mycursor
--從遊標裡取出資料賦值到我們剛才聲明的欄位名變數中
fetch next from mycursor into @ColumnName
--如果遊標執行成功
while (@@fetch_status=0)
begin
--顯示出我們每次用遊標取出的值
Set @ColumnsString=@ColumnsString+','+@ColumnName
--用遊標去取下一條記錄
fetch next from mycursor into @ColumnName
end
--關閉遊標
close mycursor
--撤銷遊標
deallocate mycursor
--如果末尾包含逗號則去除
if left(@ColumnsString,1)=',' set @ColumnsString=substring(@ColumnsString,2,len(@ColumnsString)-1)
print @ColumnsString
--多表聯集查詢
declare @GroupColumnsString nvarchar(4000) --如果顯示不全,這裡自己修改更大的數字
declare @PrefixString nvarchar(255)
set @PrefixString=@TableName --這裡可以修改成你想要的字串
set @GroupColumnsString=replace(@ColumnsString,',',','+@PrefixString+'.')
set @GroupColumnsString=@PrefixString+'.'+@GroupColumnsString
print @GroupColumnsString