如何使用 sql 语句 遍历 数据库里的表

如何使用 sql 语句 遍历 数据库里的表,第1张

---找出这个表中所有类型为varchar型的字段

---不知道你的str型需要对应哪几种类型,只以varchar型为例,其他类型可以查找systypes

---将所需要的type添加到最后的type筛选语句中

select t2.name from

(

---找到主键为aaa,并且与表中aaa字段的外键相对应的表

select b.id

from

(

---找出表1中aaa外键所对应的主表和主键

select rkeyid,rkey

from

(

---找出表1中的所有外键

select a.id,b.* from sysobjects a inner join sysforeignkeys b

on a.id=b.fkeyid

where xtype='U' and name='表1'

)c

inner join

(

---找出aaa字段所在的所有表

select id from syscolumns

where name='aaa'

)d

on c.id=d.id

)a

inner join

(

---找出aaa字段所在的所有表

select id from syscolumns

where name='aaa'

)b

on a.rkeyid=b.id

)t1

inner join syscolumns t2

on t1.id=t2.id

where t2.type=39

回答修改:

根据需求,修改如下

declare @name varchar(255)

---找出主表的名字

set @name=

(select t2.name from

(---找出SampleDetails中的lngYyGlAID外键所对应的主表

---有可能SampleDetails中不只有一个外键

---如果确定只有一个外键,不用和d相交

select rkeyid

from

(

---找出SampleDetails中的所有外键

select a.id,b.* from sysobjects a inner join sysforeignkeys b

on a.id=b.fkeyid

where xtype='U' and name='SampleDetails'

)c

inner join

(

---找出lngYyGlAID字段所在的所有表

select id from syscolumns

where name='lngYyGlAID'

)d

on c.id=d.id)t1

inner join

sysobjects t2

on t1.rkeyid=t2.id)

---从主表中查出strcode字段的所有信息

declare @sql varchar(255)

set @sql='select strCode from '+@name

exec(@sql)

1.先找到 存储 外键约束或者所有约束信息的表或者数据字典 假设为user_re表

2.然后再DESC 查看他有那些字段

3.再找里面相应的字段

a.约束所在表(假设字段为fk_table)

b.外键的话应该有

c.表的字段(fk_col)参照表(ref_table)和参照表的字段(ref_table.col)

这些信息肯定都有了

然后按你的要求就是

select ref_table from user_re

where fk_table = 'T1' and fk_col = 'AAA' and ref_table.col = 'AAA'

那么得到的ref_table列就是你所要找的表了!~

你自己要做的就是去查找相应的数据字典,而且可能信息存在几个表中,那么可能还设计到表的连接。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/bake/11726525.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存