笔者工作的公司采用的是SQLServer数据库,每天都要处理大量的数据,由于笔者进公司的时间比较晚,公司现有的大部分的程序都是以前的程序员留下的,因为他们没有相关的文档,笔者对于后台数据库的很多表的结构和数据都不甚了解,给日常的维护造成了很大的麻烦。
在对后台数据库进行研究的过程中,我需要得到数据库的某些相关信息,比如,公司的数据库中有几个表存放笔者的个人资料,像人事表、工资表、部门表等等,但具体是哪些表,就不是很清楚了,如果要一个一个表地找,可能天亮了也找不完,所以我决定做一个通用的存储过程,能对当前数据库所有字符型字段进行遍历,找出精确匹配含有要查找字符串的表和字段,并且罗列出来。比如,人事表的Name字段,工资表的Salary_Name字段,部门表的Employe_Name字段都有笔者的名字,我希望能把这些找出来。存储过程如下:
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'searchname' AND type = 'P')
DROP PROCEDURE searchname
Go
create procedure searchname @sname varchar(10)
As
begin
create table #TableList(
tablename char(200),
colname char(200)
)
declare @table varchar(200)
declare @col varchar(200)
set nocount on
declare curTab scroll cursor for select name from sysobjects where xtype='u'
open curTab
fetch next from curTab into @table
while @@FETCH_STATUS=0
begin
declare curCol scroll cursor for select name from syscolumns where (xtype=175 or xtype=167) and (id in (select id from sysobjects where name=@table))
open curCol
fetch next from curCol into @col
while @@FETCH_STATUS=0
begin
execute('insert into #TableList select ''+@table+'',''+@col+'' from '+@table+' where '+@col+'=''+@sname+'')
fetch next from curCol into @col
end
close curCol
deallocate curCol
fetch next from curTab into @table
end
close curTab
deallocate curTab
set nocount off
select distinct * from #TableList
drop table #tablelist
end
实用的存储过程2
原创文章如转载,请注明:转载自悠悠博客 [ http://www.ajaxstu.com/ ]
相关文章:
- 关于Access数据库中日期格式和货币格式的问题(2007-10-18 5:25:43)
- asp在线压缩access数据库(2007-10-7 5:27:10)
- 数据库设计技巧(2007-10-2 7:10:52)
- Access数据库过大问题的几种解决方案(2007-9-3 1:21:55)
- Access 数据库表规格(2007-9-1 7:4:57)
- 保护Access数据库的安全(2007-6-13 7:43:49)
- 以编程方式创建“自动编号”字段并将其“新值”属性设置为“随机”(2007-6-11 10:52:33)
- 读取Access数据库表名实例(2007-5-22 1:10:0)
- asp access的安全:不要认为简单的改后缀mdb为asp就能防下载(2007-5-10 7:11:56)
- 通用删除某表某字段满足条件的记录两个函数(2007-5-9 7:4:22)
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
