MSSQL查找数据所在的表与列

本人无意中需要帮助维护我们的邻居-----巴伦台医院的医院管理系统。

其中在一次医保数据上传的过程中提示 病人 74828429  插入错误,处方号不能为空。

经查,发现是把医院管理系统的 sql2000数据库的内容,经过处理之后,插入到oracle8 数据库中。

那么这里只提示了oracle8的表名列名。却没有提供源数据库 sql2000的表名列名

好吧,那么我们在源数据库里找。sql2000吗,用了8年了,还不熟悉么。

可是,一打开,就傻眼了,天啦,816个表%&$#@#…………

没办法,只好请教CSDN的高手。一天以后,网友 wxg22526451 给了答案。

在查询分析器中执行如下语句:

declare @str varchar(100)
set @str='这里请自己填写'  --要搜索的字符串

declare @s varchar(8000)
declare tb cursor local for
select s='if exists(select 1 from ['+b.name+'] where ['+a.name+'] like

''%'+@str+'%'')
 print ''所在的表及字段: ['+b.name+'].['+a.name+']'''
from syscolumns a join sysobjects b on a.id=b.id
where b.xtype='U' and a.status>=0
 and a.xusertype in(175,239,231,167)
open tb
fetch next from tb into @s
while @@fetch_status=0
begin
 exec(@s)
 fetch next from tb into @s
end
close tb
deallocate tb

在一分钟之后,计算机给出了答案,顺利找到了这个数据所在的表、列。问题自然就解决了。

在这里特别感谢热心的csdn网友,包括其它的几位给出不同方案的朋友,感谢csdn网。

同时,特将此代码帖出来,以方便大家学习、参考、研究。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值