Oracle 实时同步 Postgre 如何实现?

Oracle 实时同步 Postgre 如何实现?,第1张

数据库A为主数据库。。当数据库A中有数据更新,删除或者新增。用触发器把所有有改动的信息记录到临时表中。然后数据库BDBLINK到数据库A。同时在DBLINK数据库A的临时表中建立一个触发器。如果临时表中有变动。那么就直接更新到数据库B中。这个我以前做的一个系统中的数据库同步步骤。不知道对你有没有用。

SQL SERVER连接oracle数据库几种方法

--1 方式

--查询oracle数据库中的表

SELECT *

FROM OPENDATASOURCE(

'MSDAORA',

'Data Source=GE160User ID=DAIMINPassword=DAIMIN'

)..DAIMIN.JOBS

--在sqlserver中创建与oracle数据库中的表同名的表

select * into JOBS from

OPENDATASOURCE(

'MSDAORA',

'Data Source=GE160User

ID=daiminPassword=daimin'

)..DAIMIN.JOBS

select * from JOBS

--2、方式

--在master数据库中查看已经存在的链接服务器

select * from sysservers

EXEC sp_addlinkedserver

@server = 'GE160',

@srvproduct = 'Oracle',

@provider = 'MSDAORA',

@datasrc = 'GE160'

exec sp_addlinkedsrvlogin 'GE160', false, 'sa', 'daimin', 'daimin'

--要在企业管理器内指定登录帐号

exec sp_dropserver GE160

select * from GE160..DAIMIN.JOBS

delete from GE160..DAIMIN.JOBS

--备注:引用ORACLE服务器上的表时,用户名称与表名一定要大写字母。

SELECT *

FROM OPENQUERY(GE160, 'SELECT * FROM DAIMIN.JOBS')

--3、方式

SELECT a.*

FROM OPENROWSET('MSDAORA',

'GE160''DAIMIN''DAIMIN',

DAIMIN.JOBS) AS a

ORDER BY a.JOB_ID

--4、方式 ODBC

--ODBC方式比较好办

SELECT A.*

FROM

OPENROWSET('MSDAORA','GE160''DAIMIN''DAIMIN', --GE160是数据源名

DAIMIN.JOBS) AS

A

ORDER BY A.JOB_ID


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9985431.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存