zoukankan      html  css  js  c++  java
  • SQLSERVER查询整个数据库中某个特定值所在的表和字段的方法

          这几天有业务部门需要使用一个SAP B1老系统  中的报表,但是由于此报表没有加时间条件,导致一旦开始查询 就会导致B1系统异常退出。由于报表对应的SQL 是存在数据库中,所以想通过查找到这个报表的SQL,然后给SQL加时间条件的方式来处理(多年前的一个报表,不知道内部逻辑,很难重写)。 

         但是苦于不清楚报表相关的表结构,不知道报表的存储位置,但只知道报表的名称 又陷入了不知道下一步该怎么处理的窘境。于是又开始大胆猜想,是不是有什么方法 可以根据数据的关键词 查询数据所在的表名呢?于是开始百度各种资料,证明 思路是可以行得通的,大致思路就是遍历每一个表的每一个字段 查询此字段是否包含关键词 。最终查到这篇文章写的方法 很不错,和大家分享下,同时也感谢博主的分享。https://blog.csdn.net/zengcong2013/article/details/55264202

    CREATE PROCEDURE [dbo].[SP_FindValueInDB]
    (
        @value VARCHAR(1024)
    ) 
    AS
    BEGIN
        SET NOCOUNT ON;
        DECLARE @sql VARCHAR(1024) 
        DECLARE @table VARCHAR(64) 
        DECLARE @column VARCHAR(64) 
        CREATE TABLE #t ( 
            tablename VARCHAR(64), 
            columnname VARCHAR(64) 
        ) 
        DECLARE TABLES CURSOR FOR 
        SELECT o.name, c.name FROM syscolumns c 
        INNER JOIN sysobjects o ON c.id = o.id 
        WHERE o.type = 'U' AND c.xtype IN (167, 175, 231, 239) 
        ORDER BY o.name, c.name 
        OPEN TABLES 
            FETCH NEXT FROM TABLES 
            INTO @table, @column 
            WHILE @@FETCH_STATUS = 0 
            BEGIN 
                SET @sql = 'IF EXISTS(SELECT NULL FROM [' + @table + '] ' 
                SET @sql = @sql + 'WHERE RTRIM(LTRIM([' + @column + '])) LIKE ''%' + @value + '%'') ' 
                SET @sql = @sql + 'INSERT INTO #t VALUES (''' + @table + ''', ''' 
                SET @sql = @sql + @column + ''')' 
                EXEC(@sql) 
                FETCH NEXT FROM TABLES 
                INTO @table, @column 
            END 
        CLOSE TABLES 
        DEALLOCATE TABLES 
        SELECT * FROM #t 
        DROP TABLE #t 
    End

    只需要传入一个想要查找的值,即可查询出这个值所在的表和字段名。

    exec [SP_FindValueInDB]  '仓库转储申请单'

     查询出来的结果如下:

    完美解决我的问题,再次感谢博主的分享 踏雪无痕

  • 相关阅读:
    curl 的用法指南
    详说 Cookie, LocalStorage 与 SessionStorage
    session,cookie和token究竟是什么
    SSL/TLS协议交互流程分析
    SSL/TLS协议运行机制的概述
    SSL常见的几个类型说明
    HTTP 的前世今生:一次性搞懂 HTTP、HTTPS、SPDY、HTT
    汉化版的脚本
    可以快速的展现当前服务器的配置、IO、SpeedTest内置下载速度的脚本
    F5 清除http 缓存
  • 原文地址:https://www.cnblogs.com/nov5026/p/8630150.html
Copyright © 2011-2022 走看看