数据库获取当前数据库的所有字段是否包含某个字符串

--select * from  sys.tables --获取当前数据库所有表
--select * from  sys.columns --获取当前数据库的所有字段

declare @str1 nvarchar(max)
set @str1 = '%LiveInHK%'

declare @str2 nvarchar(max)
set @str2 = '%Live in hong kong%'

declare @str3 nvarchar(max)
set @str3 = '%居住在香港%'

create table #t_column(table_name nvarchar(max),column_name nvarchar(max))
insert into #t_column
select a.name as table_name,b.name as column_name
from sys.tables a,sys.columns b
where a.object_id = b.object_id
order by a.name

declare cur cursor for select * from #t_column
open cur
declare @table_name nvarchar(max),@column_name nvarchar(max)
fetch next from cur into @table_name,@column_name
while(@@FETCH_STATUS = 0)
begin
    begin try
        --exec('if exists(select 1 from ' + @table_name + ' where ' + @column_name + ' = ' + '''' + @str + ''') ' + ' print ''' + @table_name + '''' +  ' + ''   ---   '' + ''' + @column_name + '''')
        exec('if exists(select 1 from ' + @table_name + ' where ' + @column_name + ' like ' + '''' + @str1 + ''') ' + ' print ''' + @table_name + '''' +  ' + ''   ---   '' + ''' + @column_name + '''')

         exec('if exists(select 1 from ' + @table_name + ' where ' + @column_name + ' like ' + '''' + @str2 + ''') ' + ' print ''' + @table_name + '''' +  ' + ''   ---   '' + ''' + @column_name + '''')

         exec('if exists(select 1 from ' + @table_name + ' where ' + @column_name + ' like ' + '''' + @str3 + ''') ' + ' print ''' + @table_name + '''' +  ' + ''   ---   '' + ''' + @column_name + '''')

    end try
    begin catch
        --print error_message()
    end catch
    fetch next from cur into @table_name,@column_name
end

close cur
deallocate cur
drop table #t_column

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值