查询服务器上所有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

搞定

相关推荐
星马梦缘1 小时前
数据库作战记录1
数据库·sql·mysql
巨斧空间掌门3 小时前
JDK17 下载 windows Linux
linux·运维·服务器
短剑重铸之日3 小时前
《ShardingSphere解读》07 读写分离:如何集成分库分表+数据库主从架构?
java·数据库·后端·架构·shardingsphere·分库分表
njidf3 小时前
用Python制作一个文字冒险游戏
jvm·数据库·python
江畔何人初4 小时前
kube-apiserver、kube-proxy、Calico 关系
运维·服务器·网络·云原生·kubernetes
鸡蛋灌Bean4 小时前
MySQL优化系列
数据库·mysql
数巨小码人4 小时前
平滑迁移:传统到国产数据库的2026转型之路
数据库
皮卡蛋炒饭.5 小时前
进程得控制
linux·运维·服务器
麦聪聊数据5 小时前
QuickAPI 在系统数据 API 化中的架构选型与集成
数据库·sql·低代码·微服务·架构
2403_835568475 小时前
自然语言处理(NLP)入门:使用NLTK和Spacy
jvm·数据库·python