增量数据库同步软件PanguSync侵入式全面清理脚本

2024-06-15 23:04

本文主要是介绍增量数据库同步软件PanguSync侵入式全面清理脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Sqlserver

-- 变量声明  
DECLARE @tableName NVARCHAR(256)  
DECLARE @indexName NVARCHAR(128)  
DECLARE @triggerName NVARCHAR(256)  
DECLARE @sql NVARCHAR(MAX)  
DECLARE @constraintsname NVARCHAR(256)  
-- 声明游标来遍历所有用户表  
DECLARE curTables CURSOR FOR   
SELECT name   
FROM sys.tables   
WHERE type = 'U' -- 用户表  -- 打开游标  
OPEN curTables  
FETCH NEXT FROM curTables INTO @tableName  -- 循环遍历所有表  
WHILE @@FETCH_STATUS = 0  
BEGIN  -- 删除索引source  BEGIN TRY  SELECT @indexName = name  FROM sys.indexes  WHERE object_id = OBJECT_ID(@tableName)  AND name = 'I_PanguSyncSourceTimestamp'  IF @indexName IS NOT NULL  BEGIN  SET @sql = 'DROP INDEX ' + QUOTENAME(@indexName) + ' ON ' + QUOTENAME(@tableName) + ';'  EXEC sp_executesql @sql  PRINT 'Index I_PanguSyncSourceTimestamp dropped from ' + @tableName + '.'  END  END TRY  BEGIN CATCH  PRINT 'Error dropping index I_PanguSyncSourceTimestamp from ' + @tableName + '. Error: ' + ERROR_MESSAGE()  END CATCH  --删除CONSTRAINT sourceSELECT top 1 @constraintsname= c.name FROM sysconstraints a 
INNER JOIN syscolumns b  on a.colid=b.colid
INNER JOIN sysobjects c  on a.constid=c.id
WHERE a.id=object_id(@tableName)
AND b.name='C_PanguSyncSourceTimestamp'IF @constraintsname IS NOT NULL 	BEGIN  SET @sql = 'ALTER TABLE ' + QUOTENAME(@tableName) + ' DROP CONSTRAINT '+ QUOTENAME(@constraintsname)+';'EXEC sp_executesql @sql  END  -- 删除字段  sourceIF EXISTS (  SELECT 1   FROM sys.columns   WHERE name = 'C_PanguSyncSourceTimestamp'   AND object_id = OBJECT_ID(@tableName)  )  BEGIN  SET @sql = 'ALTER TABLE ' + QUOTENAME(@tableName) + ' DROP COLUMN C_PanguSyncSourceTimestamp;'  EXEC sp_executesql @sql  PRINT 'Column C_PanguSyncSourceTimestamp dropped from ' + @tableName  END  -- 删除索引 targetBEGIN TRY  SELECT @indexName = name  FROM sys.indexes  WHERE object_id = OBJECT_ID(@tableName)  AND name = 'I_PanguSyncTargetTimestamp'  IF @indexName IS NOT NULL  BEGIN  SET @sql = 'DROP INDEX ' + QUOTENAME(@indexName) + ' ON ' + QUOTENAME(@tableName) + ';'  EXEC sp_executesql @sql  PRINT 'Index I_PanguSyncTargetTimestamp dropped from ' + @tableName + '.'  END  END TRY  BEGIN CATCH  PRINT 'Error dropping index I_PanguSyncTargetTimestamp from ' + @tableName + '. Error: ' + ERROR_MESSAGE()  END CATCH  --删除CONSTRAINT targetSELECT top 1 @constraintsname= c.name FROM sysconstraints a 
INNER JOIN syscolumns b  on a.colid=b.colid
INNER JOIN sysobjects c  on a.constid=c.id
WHERE a.id=object_id(@tableName)
AND b.name='C_PanguSyncTargetTimestamp'IF @constraintsname IS NOT NULL 	BEGIN  SET @sql = 'ALTER TABLE ' + QUOTENAME(@tableName) + ' DROP CONSTRAINT '+ QUOTENAME(@constraintsname)+';'EXEC sp_executesql @sql  END  -- 删除字段  targetIF EXISTS (  SELECT 1   FROM sys.columns   WHERE name = 'C_PanguSyncTargetTimestamp'   AND object_id = OBJECT_ID(@tableName)  )  BEGIN  SET @sql = 'ALTER TABLE ' + QUOTENAME(@tableName) + ' DROP COLUMN C_PanguSyncTargetTimestamp;'  EXEC sp_executesql @sql  PRINT 'Column C_PanguSyncTargetTimestamp dropped from ' + @tableName  END  -- 删除触发器(包含PGD或PanguSync)  DECLARE curTriggers CURSOR FOR   SELECT name   FROM sys.triggers   WHERE OBJECT_NAME(parent_id) = @tableName  AND name LIKE '%_PGD_%' OR name LIKE '%PanguSync%'  OPEN curTriggers  FETCH NEXT FROM curTriggers INTO @triggerName  WHILE @@FETCH_STATUS = 0  BEGIN  SET @sql = 'DROP TRIGGER ' + QUOTENAME(@triggerName) + ';'  EXEC sp_executesql @sql  PRINT 'Trigger ' + @triggerName + ' dropped from ' + @tableName + '.'  FETCH NEXT FROM curTriggers INTO @triggerName  END  CLOSE curTriggers  DEALLOCATE curTriggers  -- 获取下一个表名  FETCH NEXT FROM curTables INTO @tableName  
END  -- 关闭并释放游标  
CLOSE curTables  
DEALLOCATE curTables

这篇关于增量数据库同步软件PanguSync侵入式全面清理脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1064834

相关文章

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad