查询服务器上所有SQL SERVER数据库中是否包含某个字段,且该字段是否包含某个值

公司有一堆相同类别的客户,每个客户都部署了相同的一套系统,每套系统对应一个相同结构的数据库,昨天老板让查一下手机号码177xxxxx248是属于哪个客户的客户。

我要查的这个号码来自于oa_member 表中的phone 字段,我需要对所有的数据库进行查询,看哪个数据库的oa_member 表的phone字段有这个号码的记录。

然而打开SQL SERVER Managerment Studio 一看,列出一大堆数据库。

卧槽这五六十个数据库,难道要我每个数据库进行一次select?搞一次还好,如果后续动不动再弄个号码过来查一下,岂不是要疯了

于是研究了下SQL语句,看看有什么解决防范,最终还是有所收获。

目前服务器上不仅部署了不少那套系统,而且还有其他不一样的系统部署在服务器上,这样查询的时候需要先过滤掉其他系统的数据库,所以先检索下哪些数据库有oa_member表,通过下面语句就可以检索出来。

sql 复制代码
DECLARE @DBName NVARCHAR(255)
DECLARE @SQL NVARCHAR(MAX)

DECLARE DatabaseCursor CURSOR FOR
SELECT name FROM sys.databases WHERE state_desc = 'ONLINE' AND name NOT IN ('master', 'tempdb', 'model', 'msdb')

OPEN DatabaseCursor
FETCH NEXT FROM DatabaseCursor INTO @DBName

WHILE @@FETCH_STATUS = 0
BEGIN
    SET @SQL = 'IF EXISTS (SELECT * FROM [' + @DBName + '].sys.tables WHERE name = ''oa_member'') BEGIN PRINT ''' + @DBName + ' '' END'
    EXEC sp_executesql @SQL
    FETCH NEXT FROM DatabaseCursor INTO @DBName
END

CLOSE DatabaseCursor
DEALLOCATE DatabaseCursor

通过以上SQL语句可以检索出所有我需要的数据库,所以再加上那个号码作为过滤条件其实就能立马筛选出该号码是哪个数据库的了

sql 复制代码
DECLARE @DBName NVARCHAR(255)
DECLARE @SQL NVARCHAR(MAX)

DECLARE @PhoneNumber NVARCHAR(20) = '177xxxxxxx248' -- 要查询的手机号码

DECLARE DatabaseCursor CURSOR FOR
SELECT name FROM sys.databases WHERE state_desc = 'ONLINE' AND name NOT IN ('master', 'tempdb', 'model', 'msdb')

OPEN DatabaseCursor
FETCH NEXT FROM DatabaseCursor INTO @DBName

WHILE @@FETCH_STATUS = 0
BEGIN
    SET @SQL = 'IF EXISTS (SELECT * FROM [' + @DBName + '].sys.tables WHERE name = ''oa_member'' AND schema_id = SCHEMA_ID(''dbo'')) BEGIN IF EXISTS (SELECT * FROM [' + @DBName + '].dbo.oa_member WHERE phone = ''' + @PhoneNumber + ''') BEGIN PRINT ''' + @DBName + ' 有号码 ' + @PhoneNumber + ''' END END'
    EXEC sp_executesql @SQL
    FETCH NEXT FROM DatabaseCursor INTO @DBName
END

CLOSE DatabaseCursor
DEALLOCATE DatabaseCursor

看到这里,就知道这个号码是属于哪个客户的了

只需要进入ChangShuZhiTangBaoQinChanSi 数据库对oa_member 表进行查询的同时通过phone字段过滤,就能查到该号码对应的信息了

sql 复制代码
use ChangShuZhiTangBaoQinChanSi
go

select * from oa_member where phone ='177xxxxx248'
go

搞定

相关推荐
zfxwasaboy5 小时前
Linux宏clamp(val, lo, hi)的作用
linux·运维·服务器
成为大佬先秃头5 小时前
数据库连接池:Druid
数据库·mysql·druid
李彦亮老师(本人)8 小时前
【Linux系统】Rocky Linux 9.7操作系统简介
linux·运维·服务器·docker·kubernetes
minji...8 小时前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法
晓华-warm8 小时前
Warm-Flow 1.8.5 正式发布:超时自动审批、暂存功能来了!
数据库
何中应8 小时前
Grafana如何重置密码
linux·运维·服务器·grafana
u0136863829 小时前
将Python Web应用部署到服务器(Docker + Nginx)
jvm·数据库·python
light blue bird9 小时前
多页签Razor组支轴业务整顿组件
数据库·.net·ai大数据·多功能图表报表·web mvc + razor
wregjru9 小时前
【mysql】2.数据表操作
数据库·mysql
手握风云-9 小时前
基于 Java 的网页聊天室(三)
服务器·前端·数据库