Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/date/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 如何选择列作为行?_Sql_Sql Server_Tsql_Dynamic Sql - Fatal编程技术网

Sql 如何选择列作为行?

Sql 如何选择列作为行?,sql,sql-server,tsql,dynamic-sql,Sql,Sql Server,Tsql,Dynamic Sql,所以,我一直在四处寻找,我发现了与我的问题相似的东西,但我需要更多的帮助才能找到真正的解决方案 我试图构造一个查询,返回两列数据,第一列应该是列名本身的列表,第二列应该是该列的值 从视觉上看是这样的 Column1 Column2 ------- ------- columnA value_of_columnA columnB value_of_columnB ... ... SELECT 'Column_Name' AS Column

所以,我一直在四处寻找,我发现了与我的问题相似的东西,但我需要更多的帮助才能找到真正的解决方案

我试图构造一个查询,返回两列数据,第一列应该是列名本身的列表,第二列应该是该列的值

从视觉上看是这样的

Column1      Column2
-------      -------
columnA      value_of_columnA
columnB      value_of_columnB
...          ...
SELECT 'Column_Name' AS ColumnName, 
  (SELECT TOP 1 Column_Name FROM Table tbl2 WHERE tbl.ID = tbl2.ID)
FROM Table tbl
我很确定这需要动态SQL来实现,但我甚至不知道如何开始创建查询


感谢您的帮助

你总是可以这样做的

Column1      Column2
-------      -------
columnA      value_of_columnA
columnB      value_of_columnB
...          ...
select column_name,* from information_schema.columns
 where table_name = 'TheTableName'
order by ordinal_position
SELECT 'Column_Name' AS ColumnName, 
  (SELECT TOP 1 Column_Name FROM Table tbl2 WHERE tbl.ID = tbl2.ID)
FROM Table tbl

这应该适用于任何表,但在我的示例中,我只是创建了一个测试表。您需要在@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(max)替换为varchar(8000),并使用它代替上面代码中的
SELECT@YourQuery
query:

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

由于SQL Server 2000没有使用SQL Server 2005的XML功能,因此使用SQL Server 2000将更容易。

您不太清楚如何显示报表以及生成报表的内容。您是否使用查询工具的直接结果生成“报告”?在这种情况下,我想你是想用螺丝刀敲打钉子。使用正确的工具进行作业

SQL语言不应直接用于设置表示数据以生成报告。真的,这是个愚蠢的想法。您可以使用直接的SQL语句编写报告,这并不意味着您应该这样做

您确实应该使用自己编写的应用程序或Crystal Reports之类的报告生成工具生成报告

自己编写的应用程序:如果使用游标对象查询数据库,只需从该游标对象获取列名即可。问题解决了

报表生成工具:通常它们提供一种工具来表示可能出现的动态数据


无论哪种方式,我认为您都需要重新考虑您的方法。

您的问题缺乏任何真正的细节-您处理的是什么表,列数据类型是什么?还有SQL Server的版本。具体是什么版本的SQL Server?您是否只希望有一行数据,或者第1列是列名,其他所有列是该列的数据?我可以理解您希望将行转换为列,而将列转换为行?您实际上想做什么?很抱歉,没有提供详细信息,查询是针对mssql 2000 db运行的。列1将只作为列名称。。。类似于此查询将从信息\u架构中提取选择列\u名称。其中表\u名称='TABLE'和column2将是从此查询中提取的信息的列选择column1、column2、column3。。。从表中blah='blah',除了我需要根据第一个查询的拉取内容动态拉取该查询之外,其中column1、column2、column3将用第一个查询的结果填充。另外,第二列中的所有数据都应该是布尔值。我不得不问,你到底为什么要这样做?除非你的表只有一条记录,否则没有意义。这看起来正是我需要的。。。除了我使用的是MSSQL 2000数据库,所以varchar(max)不起作用,尽管我用varchar(1000)解决了这个问题,而FOR XML PATH(“”)也不起作用。我不知道该怎么避开那个。。。