[英]How to concatenate all columns in a select with SQL Server
我需要我的選擇具有這樣的模式:
SELECT '<text> ' + tbl.* + ' </text>' FROM table tbl;
理想的解決方案是將所有列用逗號分隔以便獲得該輸出:
表 1 的 SQL 結果有兩列:
'<text>col1, col2</text>'
具有三列的表 2 的 SQL 結果:
'<text>col1, col2, col3</text>'
我嘗試像這樣使用CONCAT(...)
函數:
SELECT CONCAT('<text>', tbl.*, '</text>')
FROM table2 tbl
但我明白這不是那么簡單,因為列數可變。
有沒有簡單的解決方案來解決這個問題?
我正在使用 SQL Server 2008 R2。
給定表名的任意數量的列; 如果您需要用<text>
包裹的列名
DECLARE @s VARCHAR(500)
SELECT @s = ISNULL(@s+', ','') + c.name
FROM sys.all_columns c join sys.tables t
ON c.object_id = t.object_id
WHERE t.name = 'YourTableName'
SELECT '<text>' + @s + '</text>'
SQL Fiddle示例在這里
-- RESULTS
<text>col1, col2, col3,...</text>
如果您需要選擇用<text>
包裹的查詢結果集,那么;
SELECT @S = ISNULL( @S+ ')' +'+'',''+ ','') + 'convert(varchar(50), ' + c.name FROM
sys.all_columns c join sys.tables t
ON c.object_id = t.object_id
WHERE t.name = 'YourTableName'
EXEC( 'SELECT ''<text>''+' + @s + ')+' + '''</text>'' FROM YourTableName')
SQL Fiddle示例在這里
--RESULTS
<text>c1r1,c2r1,c3r1,...</text>
<text>c1r2,c2r2,c3r2,...</text>
<text>c1r3,c2r3,c3r3,...</text>
MS SQL Server 2008 架構設置:
create table YourTable
(
ID int identity primary key,
Name varchar(50),
)
insert into YourTable values
('Name 1'),
('Name 2'),
('Name 3'),
('Name 4'),
('Name 5')
查詢 1 :
select (
select (
select ', '+T2.N.value('./text()[1]', 'varchar(max)')
from (
select T.*
for xml path(''), type
) as T1(N)
cross apply T1.N.nodes('/*') as T2(N)
for xml path(''), type
).value('substring(./text()[1], 3)', 'varchar(max)')
for xml path('text'), type
)
from YourTable as T
結果:
| COLUMN_0 |
--------------------------
| <text>1, Name 1</text> |
| <text>2, Name 2</text> |
| <text>3, Name 3</text> |
| <text>4, Name 4</text> |
| <text>5, Name 5</text> |
我嘗試了一種更通用的方法
Create Procedure P_GetConcatColumns(@tablename varchar(200),@Seperator Varchar(20),@StartTag Varchar(20),@EndTag Varchar(20),@WhereString Varchar(400),@OrderString Varchar(400)) as
DECLARE @TmpTableName VARCHAR(100),
@Columns NVARCHAR(4000),
@SQL NVARCHAR(MAX),
@GENNAME VARCHAR(100)
Select @GENNAME='##'+Replace(Cast(NewID() as Varchar(40)),'-','')
IF OBJECT_ID('tempdb.dbo.' + @GENNAME) IS NOT NULL
BEGIN
EXEC('DROP TABLE ' +@GENNAME);
END
Select @SQL='SELECT TOP 1 * INTO '+@GENNAME+' FROM ' + @tablename
Exec (@SQL)
SET @TmpTableName = 'tempdb.dbo.' + @GENNAME
SELECT @Columns =
STUFF(
(
SELECT '+' + @Seperator + '+CAST(Coalesce(' + c.name + ','''') AS VARCHAR(MAX))' + CHAR(13)
FROM tempdb.sys.columns c
WHERE c.[object_id] = object_Id(@TmpTableName)
FOR XML PATH(''),TYPE
).value('.','VARCHAR(MAX)')
,1,len(@Seperator)+2,'')
--SET @SQL = N'SELECT ' +''''+ @StartTag +''''+'+'+ @Columns +''''+'+'+ @EndTag + ''' FROM ' + @tablename
SET @SQL = N'SELECT ''' +@StartTag+ '''+'+ @Columns +'+'''+ @EndTag + ''' FROM ' + @tablename
+' '+Coalesce(@WhereString,'')
+' '+Coalesce(@OrderString,'')
Print @SQL
EXEC sp_executeSQL @SQL
--ExampleCall P_GetConcatColumns 'Arten',''',''','<test>','</test>','where id>1','Order by ID desc'
試試下面的代碼:
SELECT Stuff(
(SELECT N', ' + COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS
where TABLE_NAME = 'YourTableName' FOR XML PATH(''),TYPE)
.value('text( [1]','nvarchar(max)'),1,2,N'')
IBMDB2:使用所需的分隔符創建文件,例如下面的分隔符='#|#'
第 1 步:-運行以下查詢,您將在 query_to_execute 列中獲得 SQL 語句:
select table_name, 'select '||listagg(column_name, '||''#|#''||')||' from '||trim(table_schema)||'.'||(table_name) as query_to_execute
from qsys2.SYSCOLUMNS
where table_name in ('YOURTABLE1', 'YOURTABLE2')
and table_schema = 'YOURSCHEMA'
group by table_schema, table_name
第2 步:-運行上面形成的查詢以在 SQL 中獲取帶分隔符的文件。
Step3a (如果從本機 iSeries 運行 SQL):將結果移動到平面文件,並將平面文件導入/FTP_get 到其他平台。
Step3b (如果使用 Windows 的查詢工具運行 SQL):將結果導出到您選擇的 file_name.xxx。
通過這種方式,您可以創建一個 CSV 文件或一個帶有我們選擇的分隔符的分隔文件。
/尼拉傑·庫馬爾
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.