0

我需要在许多表的列中找到所有响应的 MAX LEN。其中一些列名跨表匹配,有些则不匹配。如果它们匹配,我需要在它匹配的所有表中使用列名。因此,假设 10 个表共有 200 个不同的列名。我创建了一个 TempCol 表。我也有一个临时表中的所有表名。我的想法是将 cols 添加到 Table1MAX、Table1MIN、Table2MAX、Table2MIN 等的 TempCol 表中。

这会找到 MAX(如果 Col_1 在表 1 中):

SELECT MAX(LEN(Col_1)) FROM Table1

我想用上面的值填写 TempCol 表,但我一直碰壁。有人有什么想法吗?

4

1 回答 1

0

这是一种方法,仅适用于 MAX 长度;您可以将其用作起点并修改/扩展它以在结果表中包含更多信息:

create table dbo.Results (
    TableName sysname not null,
    ColumnName sysname not null,
    MaxLength int not null default 0,
    primary key (TableName, ColumnName)
)

insert into dbo.Results (TableName, ColumnName)
select object_name(sc.object_id), sc.name
from sys.columns sc
join sys.types st
on sc.system_type_id = st.system_type_id
-- get data for varchar(max) columns only
where st.name = 'varchar' and sc.max_length = -1 

declare @TableName sysname, @ColumnName sysname, @sql nvarchar(max)

declare TablesAndColumns cursor local fast_forward
for
select TableName, ColumnName
from dbo.Results

open TablesAndColumns
fetch next from TablesAndColumns into @TableName, @ColumnName
while @@fetch_status = 0
begin
    set @sql =  'update dbo.Results set MaxLength = (select isnull(max(len(' + @ColumnName + ')),0) ' +
                ' from ' + @TableName + ') ' +
                ' where TableName = ''' + @TableName + ''' and ColumnName = ''' + @ColumnName + ''''
    print @sql      
    exec sp_executesql @sql

    fetch next from TablesAndColumns into @TableName, @ColumnName
end

close TablesAndColumns
deallocate TablesAndColumns

select * from dbo.Results

使用游标和动态 SQL 并不总是一个好主意,但对于像这样的一次性系统任务来说,这是一种合理的方法。

于 2013-05-01T19:44:24.700 回答