zoukankan      html  css  js  c++  java
  • 在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

  • 相关阅读:
    数据解压
    子区域数据合并
    数据压缩复制
    将Win10变回Win7/WinXP界面
    通过GP加载卫星云图-雷达图-降雨预报图
    Maven版本与JDK版本
    由输入法随想
    selinux开关
    android studio 配置
    NodeJS 笔记
  • 原文地址:https://www.cnblogs.com/thinkCoding/p/2285905.html
Copyright © 2011-2022 走看看