• 在Sql Server 数据库中找到含某个词的所有字段


    问题:找到含某个词的所有表和字段

    思路:循环 INFORMATION_SCHEMA.COLUMNS  ,找到所有的表和列,并尝试用select count(1) 的方式 ,如果,返回值大于0,说明,存在,否则不存在。

    注意点:INFORMATION_SCHEMA.COLUMNS 要进行DATA_TYPE='nvarchar'的筛选,这个根据你所查的值是什么 类型而定。

    存储过程

       
    CREATE proc [dbo].[sp_FindCol]
    @strLookfor nvarchar(128)
    as
    begin
    DECLARE @num int
    DECLARE @sql nvarchar(400)
    DECLARE @tablename nvarchar(128)
    DECLARE @tableColumn nvarchar(128)
    DECLARE @ParmDefinition nvarchar(128)
    DECLARE tnames_cursor CURSOR
    FOR
    SELECT TABLE_NAME,COLUMN_NAME
    FROM INFORMATION_SCHEMA.COLUMNS where DATA_TYPE='nvarchar'
    OPEN tnames_cursor

    FETCH NEXT FROM tnames_cursor INTO @tablename,@tableColumn
    While @@fetch_status=0
    Begin
    set @sql='select @num = COUNT(1) from '+ @tablename+' where '+ @tableColumn+'='+''''+@strLookfor+''''
    --print @sql
    SET @ParmDefinition = N'@num int OUT,@tablename nvarchar(128),@tableColumn nvarchar(128),@strLookfor nvarchar(128)'

    EXECUTE sp_executesql @sql,@ParmDefinition,@num OUT,@tablename,@tableColumn,@strLookfor
    if @num<>0
    begin
    set @sql=N' insert into t1(A,B) values('''+@tablename+''','''+@tableColumn+''')'
    --print @sql
    --print @num
    EXECUTE (@sql)
    end
    Fetch Next From tnames_cursor Into @tablename,@tableColumn
    End
    print @num
    Close tnames_cursor
    Deallocate tnames_cursor
    end

    t1 表结构如下:

    CREATE TABLE [dbo].[t1](
    [A] [nvarchar](128) NULL,
    [B] [nvarchar](128) NULL
    )


    关于 INFORMATION_SCHEMA的更多信息见官方文档

     http://msdn.microsoft.com/zh-cn/library/ms188348(v=SQL.100).aspx

     http://msdn.microsoft.com/zh-cn/library/ms186778(v=SQL.100).aspx

  • 相关阅读:
    空矩形星星排列图源程序
    点名源程序
    计数器
    按键
    游戏石头剪刀布
    PCB自动生成总图和子图
    对于电脑中文件的一些处理
    一般电脑软件整体缩进和缩退快捷键
    java从小到大循环打印
    STM(WIFI模块)
  • 原文地址:https://www.cnblogs.com/thinkCoding/p/2285905.html
Copyright © 2020-2023  润新知