如何使用 SQL Server 连接选择中的所有列

How to concatenate all columns in a select with SQL Server(如何使用 SQL Server 连接选择中的所有列)
本文介绍了如何使用 SQL Server 连接选择中的所有列的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要我的选择有这样的模式:

I need my select to have a pattern like this:

 SELECT '<text> ' + tbl.* + ' </text>' FROM table tbl;

理想的解决方案是将所有列用逗号分隔,以便获得该输出:

The ideal solution would have all the columns separated by a comma in order to have that output:

表 1 的两列 SQL 结果:

SQL result for Table 1 with two columns:

'<text>col1, col2</text>'

表 2 三列的 SQL 结果:

SQL result for Table 2 with three columns:

'<text>col1, col2, col3</text>' 

我尝试像这样使用 CONCAT(...) 函数:

I tried to use the CONCAT(...) function like this:

SELECT CONCAT('<text>', tbl.*, '</text>')
FROM table2 tbl

但我知道它不是那么简单,因为列数可变.

But I understand it is not so simple because the variable number of columns.

有什么简单的方法可以解决这个问题吗?

Is there any simple solution to address that problem?

我使用的是 SQL Server 2008 R2.

I am using 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> 选择查询 结果集 则;

If you need select query result set wrapped with <text> then;

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>

这篇关于如何使用 SQL Server 连接选择中的所有列的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)