SQL SERVER——生成sql:删除所有log表中,user_name是某用户的数据

前言

等保要求去掉admin账户,并且删除所有admin产生的日志。

由于数据库太多,一个一个找太麻烦,于是就有了这篇文章:

总体思路:

  1. 遍历所有用户数据库
  2. 表名匹配 %LOG%
  3. 确保有 user_name 字段
  4. 支持任意 Schema
sql 复制代码
-- 创建临时表存储所有 DELETE 语句
CREATE TABLE #DeleteStatements (DeleteStatement NVARCHAR(4000));

DECLARE @dbname SYSNAME;
DECLARE @sql NVARCHAR(MAX);

-- 声明局部游标(避免命名冲突)
DECLARE db_cursor CURSOR LOCAL FOR
    SELECT name
    FROM sys.databases
    WHERE database_id > 4          -- 排除系统数据库
      AND state = 0                -- 在线
      AND is_read_only = 0;        -- 可写

OPEN db_cursor;
FETCH NEXT FROM db_cursor INTO @dbname;

WHILE @@FETCH_STATUS = 0
BEGIN
    -- 动态构建查询:找出当前库中 表名含 LOG + 有 user_name 列 的表,并生成 DELETE 语句
    SET @sql = N'
        INSERT INTO #DeleteStatements (DeleteStatement)
        SELECT 
            ''DELETE FROM '' + 
            QUOTENAME(''' + @dbname + ''') + ''.'' + 
            QUOTENAME(s.name) + ''.'' + 
            QUOTENAME(t.name) + 
            '' WHERE user_name = ''''admin'''';''
        FROM ' + QUOTENAME(@dbname) + N'.sys.tables t
        INNER JOIN ' + QUOTENAME(@dbname) + N'.sys.schemas s ON t.schema_id = s.schema_id
        INNER JOIN ' + QUOTENAME(@dbname) + N'.sys.columns c ON t.object_id = c.object_id
        WHERE UPPER(t.name) LIKE ''%LOG%''
          AND c.name = ''user_name''
        GROUP BY s.name, t.name;
    ';

    BEGIN TRY
        EXEC sp_executesql @sql;
    END TRY
    BEGIN CATCH
        -- 忽略无法访问的数据库(如权限不足、脱机等)
        PRINT 'Skipped database: ' + @dbname + ' (' + ERROR_MESSAGE() + ')';
    END CATCH

    FETCH NEXT FROM db_cursor INTO @dbname;
END

CLOSE db_cursor;
DEALLOCATE db_cursor;

-- 一次性返回所有 DELETE 语句(单个结果集)
SELECT DeleteStatement FROM #DeleteStatements ORDER BY DeleteStatement;

-- 清理
DROP TABLE #DeleteStatements;
相关推荐
爱学习的阿磊10 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
枷锁—sha16 分钟前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞28 分钟前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle
chian-ocean29 分钟前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
m0_5500246332 分钟前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦33 分钟前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_99991 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同7652 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码2 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean2 小时前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer