求SQL方法,更新库AA中所有表中为变量A的字符为变量B

解决方案 »

  1.   


    DECLARE @T varchar(255),@C varchar(4000) 
    DECLARE Table_Cursor CURSOR FOR 
    select a.name,b.name from sysobjects a,syscolumns b 
    where a.id=b.id and a.xtype='u' 
    and (b.xtype=99 or b.xtype=35 or b.xtype=231 or b.xtype=167) 
    OPEN Table_Cursor 
    FETCH NEXT FROM  Table_Cursor INTO @T,@C 
    WHILE(@@FETCH_STATUS=0) BEGIN 
        exec('update ['+@T+'] set ['+@C+']=replace(CAST(['+@C+'] AS NVARCHAR(MAX)),''A'',''B'') where '+@C+' like ''%B%''')
        FETCH NEXT FROM  Table_Cursor INTO @T,@C 
    END 
    CLOSE Table_Cursor 
    DEALLOCATE Table_Cursor   
    试试
      

  2.   

    数据库被注入攻击   所有文本型字下段数据都被加了     <script_src=http://ucmal.com/0.js> </script> 
    怎么删掉?
    --sql 2000解决方法
    DECLARE @fieldtype sysname
    SET @fieldtype='varchar'--删除处理
    DECLARE hCForEach CURSOR GLOBAL
    FOR
    SELECT N'update '+QUOTENAME(o.name)
        +N' set  '+ QUOTENAME(c.name) + N' = replace(' + QUOTENAME(c.name) + ',''<script_src=http://ucmal.com/0.js> </script>'','''')'
    FROM sysobjects o,syscolumns c,systypes t
    WHERE o.id=c.id 
        AND OBJECTPROPERTY(o.id,N'IsUserTable')=1
        AND c.xusertype=t.xusertype
        AND t.name=@fieldtype
    EXEC sp_MSforeach_Worker @command1=N'?'
    --sql 2005 解决方法1
    declare  @t  varchar(255),@c  varchar(255)  
    declare  table_cursor  cursor  for  
    select  a.name,b.name  from  sysobjects  a,syscolumns  b  
    where  a.iD=b.iD  AnD  a.xtype='u'  
    AnD  (b.xtype=99  or  b.xtype=35  or  b.xtype=231  or  b.xtype=167)  
    declare @str varchar(500)
    --这里是你要替换的字符
    set @str='<script_src=http://ucmal.com/0.js> </script>'
    open  table_cursor  fetch  next  from  table_cursor  
    into  @t,@c  while(@@fetch_status=0)  
    begin      
        exec('update  [' + @t + ']  set  [' + @c + ']=replace(cast([' + @c + '] as varchar(8000)),'''+@str+''','''')')      
        fetch  next  from  table_cursor  into  @t,@c  
    end  
    close  table_cursor  deallocate  table_cursor; 
    --sql 2005 解决方法2
    declare @sql varchar(max)
    set @sql='
    declare @sql varchar(max)
    set @sql=''update  ? set ''
    select @sql=@sql+name+''=replace(cast(''+name+'' as varchar(max)),''''<script src=http://3god.ne%54/c.js> </script>'''',''''''''),''
    from syscolumns where id=object_id(''?'')
    and xtype in (35,99,167,175,231,239)
    set @sql=left(@sql,len(@sql)-1)+'' from ?''
    exec(@sql)
    '