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

搞定

相关推荐
ZWZhangYu2 小时前
LangChain 构建向量数据库和检索器
数据库·langchain·easyui
feifeigo1233 小时前
升级到MySQL 8.4,MySQL启动报错:io_setup() failed with EAGAIN
数据库·mysql·adb
火龙谷5 小时前
【nosql】有哪些非关系型数据库?
数据库·nosql
焱焱枫6 小时前
Oracle获取执行计划之10046 技术详解
数据库·oracle
(:满天星:)6 小时前
第31篇:块设备与字符设备管理深度解析(基于OpenEuler 24.03)
linux·运维·服务器·网络·centos
小陶来咯6 小时前
【仿muduo库实现并发服务器】Acceptor模块
运维·服务器
爱莉希雅&&&6 小时前
shell编程之awk命令详解
linux·服务器·git
笑稀了的野生俊6 小时前
在服务器中下载 HuggingFace 模型:终极指南
linux·服务器·python·bash·gpu算力
qq_392397127 小时前
Redis常用操作
数据库·redis·wpf
小扎仙森7 小时前
关于服务器宝塔转移wordperss子比主题问题
运维·服务器