本人无意中需要帮助维护我们的邻居-----巴伦台医院的医院管理系统。
其中在一次医保数据上传的过程中提示 病人 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网。
同时,特将此代码帖出来,以方便大家学习、参考、研究。