通过SQLAgent实现Oracle与SQL Server表数据同步

将SQLServer2008中的某些表同步到Oracle数据库中,不同数据库类型之间的数据同步我们可以使用链接服务器和SQLAgent来实现

实例1:

SQLServer2008有一个表employ_epl是需要同步到一个EHR系统中(Oracle11g),实现数据库的同步步骤如下:

1.在Oracle中建立对应的employ_epl表,需要同步哪些字段我们就建那些字段到Oracle表中。 注意:Oracle的数据类型和SQLServer的数据类型是不一样的,需要进行转换

–查看SQLServer和其他数据库系统的数据类型对应关系 –SQL转Oracle的类型对应

SELECT *FROM msdb.dbo.MSdatatype_mappings

–详细得显示了各个数据库系统的类型对应

SELECT *FROM msdb.dbo.sysdatatypemappings

2.建立链接服务器 将Oracle系统作为SQL Server的链接服务器加入到SQL Server中。

http://www.linuxidc.com/Linux/2016-04/130574.htm

3.使用SQL语句通过链接服务器将SQLServer数据写入Oracle中

DELETE FROM TESTORACLE..SCOTT.EMPLOY_EPL
insert into TESTORACLE..SCOTT.EMPLOY_EPL
select * from employ_epl

–查看Oracle数据库中是否已经有数据了。

select * from TESTORACLE..SCOTT.EMPLOY_EPL

4.建立SQLAgent,将以上同步SQL语句作为执行语句,每天定时同步。

实例2:依靠”作业”定时调度存储过程来操作数据,增,删,改,全在里面,结合触发器,游标来实现,关于作业调度,使用了5秒运行一次来实行”秒级作业”,这样基本就算比较快的”同步”

–1.准备一个新表 –SqlServer表EmployLastRec_Sql用于记录employ_epl表的增删改记录 CREATE TABLE [dbo].[EmployLastRec_Sql](https://www.zmtbox.com/tools/[id] [int] IDENTITY(1,1) NOT NULL, [modiid] [int] NULL, [IsExec] [int] NULL, [epl_employID] varchar NULL, [epl_employName] varchar NULL, [epl_Sex] [int] NULL, [epl_data] [datetime] NULL)

–2.用一个视图”封装”了一下链接服务器下的一张表

create view v_ora_employ
as
 --TESTORACLE链接服务器名
 select * from TESTORACLE..SCOTT.EMPLOY_EPL

–3.SQL2008表employ_epl建立触发器,用表EmployLastRec_Sql记录下操作的标识 –modiid等于1为insert,2为delete,3为update,字段isexec标识该条记录是否已处理,0为未执行的,1为已执行的

create trigger trg_employ_epl_insert on employ_epl for insert
as
 insert into EmployLastRec_Sql(modiid,IsExec,epl_employID,epl_employName,epl_Sex)
 select '1','0',epl_employID,epl_employName,epl_Sex from inserted


create trigger trg_employ_epl_update on employ_epl for update
as
 insert into EmployLastRec_Sql(modiid,IsExec,epl_employID,epl_employName,epl_Sex)
 select '3','0',epl_employID,epl_employName,epl_Sex from inserted


create trigger trg_employ_epl_delete on employ_epl for delete
as
 insert into EmployLastRec_Sql(modiid,IsExec,epl_employID,epl_employName,epl_Sex)
 select '2','0',epl_employID,epl_employName,epl_Sex from deleted

–4.创建存储过程进行导数到ORACLE –使用游标逐行提取EmployLastRec_Sql记录,根据modiid判断不同的数据操作,该条记录处理完毕后把isexec字段更新为1.

create proc sp_EmployLastRec_Sql
as --epl_employID,epl_employName,epl_Sex
 declare @modiid int
 declare @employID varchar(30)
 declare @employName varchar(50)
 declare @sex int

–字段IsExec标识该条记录是否已处理,0为未执行的,1为已执行的

if not exists(select * from EmployLastRec_Sql where IsExec=0)
 begin  
   truncate table EmployLastRec_Sql----不存在未执行的,则清空表
 return
 end

 declare cur_sql cursor for
   select modiid,epl_employID,epl_employName,epl_Sex
   from EmployLastRec_Sql where IsExec=0 order by [id]--IsExec 0为未执行的,1为已执行的

 open cur_sql
 fetch next from cur_sql into @modiid,@employID,@employName,@sex
 while @@fetch_status=0
 begin
   if (@modiid=1) --插入
   begin
     ----将数据插入到ORACLE表中
     insert into v_ora_employ(epl_employID,epl_employName,epl_Sex)values(@employID,@employName,@sex)
   end

•    if (@modiid=2) --删除
•    begin
•      delete from v_ora_employ where epl_employID=@employID
•    end

•    if (@modiid=3) --修改
•    begin
•      update v_ora_employ set epl_employName=@employName,epl_Sex=@sex,epl_data=getdate()
•      where epl_employID=@employID
•    end

•    update EmployLastRec_Sql set IsExec=1   where current of cur_sql

•    fetch next from cur_sql into @modiid,@employID,@employName,@sex
 end

 deallocate cur_sql

–5.调用该存储过程的作业,实现5秒执行一次该存储过程,做到5秒数据同步。 –先建一个一分钟运行一次的作业,然后在”步骤”的脚本中这样写:

DECLARE @dt datetime
SET @dt = DATEADD(minute, -1, GETDATE())
--select @dt
WHILE @dt '00:00:05' -- 等待5秒, 根据你的需要设置即可
END

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/219786.html<

(0)
运维的头像运维
上一篇2025-04-14 06:44
下一篇 2025-04-14 06:46

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注