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

搞定

相关推荐
Cosolar21 小时前
LlamaIndex索引类型全解析:原理与实战指南
运维·服务器
睡不醒男孩0308231 天前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
方便面不加香菜1 天前
Linux--基础IO(一)
linux·运维·服务器
Micro麦可乐1 天前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪1 天前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通1 天前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..1 天前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_29141 天前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜1 天前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊1 天前
mysql数据库导出导入
数据库·mysql·oracle