所以,我一直在寻找,我发现了与我的问题类似的东西,但我需要更多的帮助来获得真正的解决方案。
我正在尝试构建一个返回2列数据的查询,第一列应该是列名本身的列表,第二列应该是该列的值。
视觉上它看起来像这样
Column1 Column2
------- -------
columnA value_of_columnA
columnB value_of_columnB
... ...
我很确定这需要动态SQL来实现,但我不知道如何开始创建查询。
感谢任何帮助!
答案 0 :(得分:7)
这适用于任何表,但在我的示例中,我只创建一个测试表。您需要在@YourTableName中设置表名。此外,您需要设置@YourTableWhere以将结果限制为一行,否则输出看起来很奇怪,多行混合在一起。
试试这个:
BEGIN TRY
CREATE TABLE YourTestTable
(RowID int primary key not null identity(1,1)
,col1 int null
,col2 varchar(30)
,col3 varchar(20)
,col4 money
,StatusValue char(1)
,xyz_123 int
)
INSERT INTO YourTestTable (col1,col2,col3,col4,StatusValue,xyz_123) VALUES (1234,'wow wee!','this is a long test!',1234.56,'A',98765)
INSERT INTO YourTestTable (col1,col2,col3,col4,StatusValue,xyz_123) VALUES (543,'oh no!','short test',0,'I',12)
END TRY BEGIN CATCH END CATCH
select * from YourTestTable
DECLARE @YourTableName varchar(1000)
DECLARE @YourTableWhere varchar(1000)
DECLARE @YourQuery varchar(max)
SET @YourTableName='YourTestTable'
set @YourTableWhere='y.RowID=1'
SELECT
@YourQuery = STUFF(
(SELECT
' UNION '
+ 'SELECT '''+COLUMN_NAME+''', CONVERT(varchar(max),'+COLUMN_NAME+') FROM '+@YourTableName+' y'+ISNULL(' WHERE '+@YourTableWhere,'')
FROM INFORMATION_SCHEMA.COLUMNS
WHERE table_name = @YourTableName
FOR XML PATH('')
), 1, 7, ''
)
PRINT @YourQuery
EXEC (@YourQuery)
输出:
RowID col1 col2 col3 col4 StatusValue xyz_123
----------- ----------- ------------------------------ -------------------- --------------------- ----------- -----------
1 1234 wow wee! this is a long test! 1234.56 A 98765
2 543 oh no! short test 0.00 I 12
SELECT 'RowID', CONVERT(varchar(max),RowID) FROM YourTestTable y WHERE y.RowID=1 UNION SELECT 'col1', CONVERT(varchar(max),col1) FROM YourTestTable y WHERE y.RowID=1 UNION SELECT 'col2', CONVERT(varchar(max),col2) FROM YourTestTable y WHERE y.RowID=1 UNION SELECT 'col3', CONVERT(varchar(max),col3) FROM YourTestTable y WHERE y.RowID=1 UNION SELECT 'col4', CONVERT(varchar(max),col4) FROM YourTestTable y WHERE y.RowID=1 UNION SELECT 'StatusValue', CONVERT(varchar(max),StatusValue) FROM YourTestTable y WHERE y.RowID=1 UNION SELECT 'xyz_123', CONVERT(varchar(max),xyz_123) FROM YourTestTable y WHERE y.RowID=1
----------- ------------------------
col1 1234
col2 wow wee!
col3 this is a long test!
col4 1234.56
RowID 1
StatusValue A
xyz_123 98765
修改强>
对于SQL Server 2000兼容性,您应该能够用varchar(8000)替换varchar(max)并使用它来代替上面代码中的SELECT @YourQuery
查询:
SELECT
@YourQuery=ISNULL(@YourQuery+' UNION ','')
+ 'SELECT '''+COLUMN_NAME+''', CONVERT(varchar(max),'+COLUMN_NAME+') FROM '+@YourTableName+' y'+ISNULL(' WHERE '+@YourTableWhere,'')
FROM INFORMATION_SCHEMA.COLUMNS
WHERE table_name = @YourTableName
答案 1 :(得分:2)
select column_name,* from information_schema.columns
where table_name = 'TheTableName'
order by ordinal_position
答案 2 :(得分:0)
你可以随时做这样的事情
SELECT 'Column_Name' AS ColumnName,
(SELECT TOP 1 Column_Name FROM Table tbl2 WHERE tbl.ID = tbl2.ID)
FROM Table tbl
答案 3 :(得分:0)
My answer to this question可以更轻松地使用SQL Server 2000,因为它不使用SQL Server 2005的XML功能。
答案 4 :(得分:0)
您不清楚自己如何呈现报告以及报告的内容。您是否使用查询工具的直接结果来生成“报告”?在这种情况下,你试图用螺丝刀敲钉子。使用正确的工具完成工作。
不应使用SQL语言来设置演示文稿数据以生成报告。真的,这是一个愚蠢的想法。您可以使用直接SQL语句编写报告这一事实并不意味着您应该。
您真的应该使用自己编写的应用程序或Crystal Reports等报表生成工具生成报表。
自己编写的应用程序:如果使用游标对象查询数据库,只需从该游标对象中获取列名即可。问题解决了。
报告生成工具:通常它们提供了表示可能出现的动态数据的工具。
无论哪种方式,我认为你需要重新考虑你的方法。