oracle如何同步字段 oracle数据库之间数据同步

SQL SERVER2012同步Oracle数据我理解oracle如何同步字段的是oracle如何同步字段,oracle如何同步字段你的需求是将oracle中变化的数据同步到sqlserver中 。
我提供的解决方案是使用oracle的oggoracle如何同步字段,就是goldengate来实现 。
首先,这个需求是跨库跨平台的 , 一般sqlserver都装在win上,而oracle都装在linux上(当然,也有linux版的sqlserver,oracle也能装在win上 , 但是实现的方法和结果是一样的),但是对于ogg来讲无所谓 , ogg的特点就是可以跨库跨平台跨版本来同步数据 。
源端是oracle,目标端是sqlserver,可以使用11版本的ogg来同步数据,该版本功能够用,bug也相对少oracle如何同步字段了,我做运维也经常用 。
使用ogg的注意事项如下:
源端oracle库的同步表必须有主键 。
源端oracle库必须是force logging,必须开附加日志 。
初始化数据的时候,可以使用ogg自己的initload功能,省的还得用sqlserver的同步助手,费劲 。
oracle和sqlserver支持的字段类型不要太特殊了,比如oracle的lob字段,sqlserver的各种text字段啥的 , 这些特有的字段,ogg支持不是很好,而对于int、varchar等通用的字段就没问题了 。
最后,希望能帮到你,但是ogg这个东西对你来说可能是新的,所以你要用的话 , 得先学学 , 有问题可以问我 。
Oracle与SQL Server如何实现表数据同步有时由于项目开发的需要,必须将SQLServer2005中的某些表同步到Oracle数据库中,由其他其他系统来读取这些数据 。不同数据库类型之间的数据同步我们可以使用链接服务器和SQLAgent来实现 。假设我们这边(SQLServer2005)有一个合同管理系统,其中有表contract 和contract_project是需要同步到一个MIS系统中的(Oracle9i)那么,我们可以按照以下几步实现数据库的同步 。
1.在Oracle中建立对应的contract 和 contract_project表 , 需要同步哪些字段我们就建那些字段到Oracle表中 。
这里需要注意的是Oracle的数据类型和SQLServer的数据类型是不一样的,那么他们之间是什么样的关系拉?我们可以在SQLServer下运行:
SELECT *
FROM msdb.dbo.MSdatatype_mappings
SELECT *
FROM msdb.dbo.sysdatatypemappings
来查看SQLServer和其他数据库系统的数据类型对应关系 。第一个SQL语句是看SQL转Oracle的类型对应,而第二个表则更详细得显示了各个数据库系统的类型对应 。根据第一个表和我们的SQLServer中的字段类型我们就可以建立好Oracle表了 。
SQLServer和Oracle的对应
2.建立链接服务器 。我们将Oracle系统作为SQLServer的链接服务器加入到SQLServer中 。
具体做法参见我以前的文章
3.使用SQL语句通过链接服务器将SQLServer数据写入Oracle中 。
比如我们建立了链接服务器MIS,而Oracle中在MIS用户下面建立了表contract_project,那么我们的SQL语句就是:
DELETE FROM MIS..MIS.CONTRACT_PROJECT
--清空Oracle表中的数据
INSERT into MIS..MIS.CONTRACT_PROJECT--将SQLServer中的数据写到Oracle中
SELECT contract_id,project_code,actual_money
FROM contract_project
如果报告成功 , 那么我们的数据就已经写入到Oracle中了 。用
SELECT *
FROM MIS..MIS.CONTRACT_PROJECT
查看Oracle数据库中是否已经有数据了 。
4.建立SQLAgent,将以上同步SQL语句作为执行语句 , 每天定时同步两次 。
这样我们的同步就完成了 。
这里需要注意的是MIS..MIS.CONTRACT_PROJECT 这里必须要大写,如果是小写的话会造成同步失败 。
如何同步ORACLE和sqlserver的数据1.在Oracle中建立对应的contract 和 contract_project表 , 需要同步哪些字段我们就建那些字段到Oracle表中 。
这里需要注意的是Oracle的数据类型和SQLServer的数据类型是不一样的,那么他们之间是什么样的关系拉?我们可以在SQLServer下运行:
SELECT *
FROM msdb.dbo.MSdatatype_mappings
SELECT *
FROM msdb.dbo.sysdatatypemappings
来查看SQLServer和其他数据库系统的数据类型对应关系 。第一个SQL语句是看SQL转Oracle的类型对应,而第二个表则更详细得显示了各个数据库系统的类型对应 。根据第一个表和我们的SQLServer中的字段类型我们就可以建立好Oracle表了 。
SQLServer和Oracle的对应
2.建立链接服务器 。我们将Oracle系统作为SQLServer的链接服务器加入到SQLServer中 。
具体做法参见我以前的文章
3.使用SQL语句通过链接服务器将SQLServer数据写入Oracle中 。
比如我们建立了链接服务器MIS,而Oracle中在MIS用户下面建立了表contract_project,那么我们的SQL语句就是:
DELETE FROM MIS..MIS.CONTRACT_PROJECT
--清空Oracle表中的数据
INSERT into MIS..MIS.CONTRACT_PROJECT--将SQLServer中的数据写到Oracle中
SELECT contract_id,project_code,actual_money
FROM contract_project
如果报告成功,那么我们的数据就已经写入到Oracle中了 。用
SELECT *
FROM MIS..MIS.CONTRACT_PROJECT
查看Oracle数据库中是否已经有数据了 。
4.建立SQLAgent , 将以上同步SQL语句作为执行语句,每天定时同步两次 。
这样我们的同步就完成了 。
这里需要注意的是MIS..MIS.CONTRACT_PROJECT 这里必须要大写,如果是小写的话会造成同步失败 。
关于oracle中 根据一个表的主键数据同步更新另一个关联表的字段 。应该有一个A、B两表一一对应的字段,这边假设字段名就是sys_guid
UPDATE B SET B.USER_ID = (SELECT ID FROM A WHERE A.sys_guid=B.sys_guid);
如何将oracle表数据实时同步到sqlsever数据表中1. SQLSERVER服务器上面安装oracle客户端 , 配置服务命名(假设为 test)
2. 在SQLSERVER服务器上面建立链接服务器,脚本如下
SQL code?
SQL code-- Adding linked server:
exec sp_addlinkedserver @server = 'test' ,
@srvproduct = 'ORACLE',
@provider = 'MSDAORA',
@datasrc = 'https://www.04ip.com/post/test'
-- Adding linked server login:
exec sp_addlinkedsrvlogin @useself='false ', @rmtsrvname = 'test',
@rmtuser = 'user', --数据库用户
@rmtpassword = 'password' --密码
3. 建立一个作业,通过作业调度存储过程,存储过程使用类似的语句将oracle的数据插入到sqlserver表中
SQL code?
insert into sqlserver表 select * from test..oracle表名
4. 如果要球ORACLE数据是实时增加的,并且ORACLE记录上有递增的字段,可以在SQLSERVER上面建立一个表记录上次插入的id , 然后下次可以从上次的ID 1开始继续插入
SQL code?
insert into sqlserver表 select * from test..oracle表名 where id@id
5. 防止sqlserver同步的时候oracle仍在不断的插入,每次要取一个结束ID
SQL code?
select @endid=max(id) from test..oracle表名.
Oracle的表里面新增一个字段之后怎么同步修改表的操作,比如增加一个字段:alter table 表名 add 新列的列名 类型;
这条语句是DDL语句,在Oracle中DDL语句会自动提交事务 。
【oracle如何同步字段 oracle数据库之间数据同步】oracle如何同步字段的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于oracle数据库之间数据同步、oracle如何同步字段的信息别忘了在本站进行查找喔 。

    推荐阅读