读书人

求查询已知的一张表中某个特定值所在字

发布时间: 2012-04-10 21:03:56 作者: rapoo

求查询已知的一张表中某个特定值所在字段的方法 ?
知道表名,知道一个值,不知道是在哪个字段,怎么查?

举例不限数据表。

[解决办法]

SQL code
CREATE TABLE Test1(    ID INT IDENTITY(1,1) NOT NULL,    UserName VARCHAR(100) NOT NULL,    Age INT)INSERT INTO Test1SELECT 'A',12 UNIONSELECT 'B',13 UNIONSELECT 'C',14 UNIONSELECT 'D',15DECLARE @TableColumn TABLE(Id INT IDENTITY(1,1),ColumnName VARCHAR(100))DECLARE @TotalNum INTDECLARE @Line INTDECLARE @Count IntDECLARE @Sqls NVARCHAR(4000)DECLARE @ColumnName VARCHAR(100)SET @Line = 1INSERT INTO @TableColumn SELECT nameFROM SYS.columnsWHERE OBJECT_NAME(OBJECT_ID) = 'Test1'SELECT @TotalNum = MAX(ID)FROM @TableColumnWHILE @Line <= @TotalNumBEGIN    SELECT @ColumnName = ColumnName    FROM @TableColumn    WHERE Id = @Line         set @Sqls='select @a=count(1) from Test1 WHERE ' + @ColumnName + '= ''15'''    exec sp_executesql @Sqls,N'@a int output',@Count output         IF @Count > 0    BEGIN        SELECT '数值所在列为:' + @ColumnName    END    SET @Line = @Line + 1END
[解决办法]
把 3楼的 改一下就可以。这里引用一下3楼的。
用like
SQL code
CREATE TABLE Test1(    ID INT IDENTITY(1,1) NOT NULL,    UserName VARCHAR(100) NOT NULL,    Age INT)INSERT INTO Test1SELECT 'A',12 UNIONSELECT 'B',13 UNIONSELECT 'C',14 UNIONSELECT 'D',15DECLARE @TableColumn TABLE(Id INT IDENTITY(1,1),ColumnName VARCHAR(100))DECLARE @TotalNum INTDECLARE @Line INTDECLARE @Count IntDECLARE @Sqls NVARCHAR(4000)DECLARE @ColumnName VARCHAR(100)SET @Line = 1INSERT INTO @TableColumn SELECT nameFROM SYS.columnsWHERE OBJECT_NAME(OBJECT_ID) = 'Test1'SELECT @TotalNum = MAX(ID)FROM @TableColumnWHILE @Line <= @TotalNumBEGIN    SELECT @ColumnName = ColumnName    FROM @TableColumn    WHERE Id = @Line         set @Sqls='select @a=count(1) from Test1 WHERE ' + @ColumnName + ' like ''15%'''    exec sp_executesql @Sqls,N'@a int output',@Count output         IF @Count > 0    BEGIN        SELECT '数值所在列为:' + @ColumnName    END    SET @Line = @Line + 1END 

读书人网 >SQL Server

热点推荐