SQLSERVER查詢單個資料表所有欄位名組合成的字串指令碼

來源:互聯網
上載者:User

--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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.