日期:2014-05-18 浏览次数:20530 次
ALTER procedure [dbo].[TEST] as begin declare @t table ( a varchar(max), b varchar(max), c varchar(max) ) insert into @t values('asd','','') insert into @t values('','','') insert into @t values('','','') select a from @t where a<>'' if @@rowcount = 0 update @t set a = 'Error' select b from @t where b<>'' if @@rowcount = 0 update @t set b = 'Error' select c from @t where c<>'' if @@rowcount = 0 update @t set c = 'Error' SET NOCOUNT on select * from @t end
declare @str varchar(2000) set @str='' declare @sql varchar(2000) set @sql='' select @str=isnull(@str,',')+'update test set '+name+'='+QUOTENAME('error','''')+ ' where '+name+' is null'+char(10) from syscolumns where id=object_id('test') exec(@str) --把test换成你的表明即可
------解决方案--------------------
ALTER procedure [dbo].[TEST] as begin declare @t table ( a varchar(max), b varchar(max), c varchar(max) ) insert into @t values('asd','','') insert into @t values('','','') insert into @t values('','','') update @t set a=case when not exists(select 1 from @t where a<>'') then 'Error' else a end, b=case when not exists(select 1 from @t where b<>'') then 'Error' else b end, c=case when not exists(select 1 from @t where c<>'') then 'Error' else c end select * from @t end
------解决方案--------------------
USE Test go --IF object_id('t') IS NOT NULL -- DROP TABLE t CREATE TABLE t ( a varchar(max), b varchar(max), c varchar(max), d varchar(max), e varchar(max), f varchar(max), g varchar(max), h varchar(max) ) insert into t values('asd','','','','','','','') insert into t values('','','','','','','','') insert into t values('','','','','','','','') DECLARE @Sql NVARCHAR(MAX) SELECT @Sql=ISNULL(@Sql+NCHAR(13)+NCHAR(10),'')+'if not exists(select 1 from t where '+name+'<>'''') update t set '+name+'=''Error''' FROM sys.syscolumns WHERE id=object_id('t') EXEC (@Sql) SET NOCOUNT on select * from t