真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

oracle怎么跨數(shù)據(jù)庫(kù),oracle跨數(shù)據(jù)庫(kù)查詢數(shù)據(jù)

Oracle數(shù)據(jù)庫(kù)怎樣跨庫(kù)查詢?

在ORACLE里A庫(kù)里建立一個(gè)同義詞可把B庫(kù)的X 表映射到A庫(kù)。這樣A庫(kù)就當(dāng)本庫(kù)的表(虛擬式)使用。

成都創(chuàng)新互聯(lián)自2013年起,先為陸豐等服務(wù)建站,陸豐等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為陸豐企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。

Oracle的同義詞(synonyms)從字面上理解就是別名的意思,和試圖的功能類似,就是一種映射關(guān)系。本文介紹如何創(chuàng)建同義詞語(yǔ)句,刪除同義詞以及查看同義詞語(yǔ)句。

oracle的同義詞總結(jié):

從字面上理解就是別名的意思,和試圖的功能類似。就是一種映射關(guān)系。

1.創(chuàng)建同義詞語(yǔ)句:

create public synonym table_name for user.table_name;

其中第一個(gè)user_table和第二個(gè)user_table可以不一樣。

此外如果要?jiǎng)?chuàng)建一個(gè)遠(yuǎn)程的數(shù)據(jù)庫(kù)上的某張表的同義詞,需要先創(chuàng)建一個(gè)Database Link(數(shù)據(jù)庫(kù)連接)來(lái)擴(kuò)展訪問(wèn),然后在使用如下語(yǔ)句創(chuàng)建數(shù)據(jù)庫(kù)同義詞:create synonym table_name for table_name@DB_Link;

當(dāng)然,你可能需要在user用戶中給當(dāng)前用戶(user2)授權(quán): grant select/delete/update on user2

如何跨Oracle數(shù)據(jù)庫(kù)實(shí)現(xiàn)表級(jí)別的實(shí)時(shí)同步

一. 前言

這個(gè)問(wèn)題是上一篇文章《Oracle跨數(shù)據(jù)庫(kù)實(shí)現(xiàn)定時(shí)同步指定表中的數(shù)據(jù)》中所提問(wèn)題的進(jìn)一步延伸??紤]到對(duì)數(shù)據(jù)的實(shí)時(shí)性要求比較高,設(shè)置成定時(shí)同步,有點(diǎn)不妥,需要改善升級(jí)更改為實(shí)時(shí)同步。

下面介紹到的方式,嚴(yán)格意義上說(shuō),并沒(méi)有實(shí)現(xiàn)實(shí)時(shí)同步。是通過(guò)Oracle數(shù)據(jù)庫(kù)創(chuàng)建同義詞+DBlink的方式,來(lái)建立遠(yuǎn)程映射。在查看數(shù)據(jù)時(shí),直接去遠(yuǎn)程查詢?cè)磶?kù)中的表。

而我一直關(guān)注的是如何進(jìn)行同步數(shù)據(jù),卻沒(méi)有考慮到可以建立映射。另外,還有一點(diǎn)就是需要交代,就是同步到目標(biāo)數(shù)據(jù)庫(kù)中的表,不進(jìn)行增刪改操作,只進(jìn)行查詢的操作,這也是可以使用同義詞方式解決問(wèn)題的關(guān)鍵。

這種解決思路的出現(xiàn),多虧了在CSDN問(wèn)答時(shí),熱心網(wǎng)友的回答,下面就是問(wèn)題詳情描述。

二. 問(wèn)題描述

有兩個(gè)Oracle數(shù)據(jù)庫(kù),分別布置在不同的服務(wù)器上,系統(tǒng)均為windows2003;

這里暫且說(shuō)成是一個(gè)主數(shù)據(jù)庫(kù)和從數(shù)據(jù)庫(kù):

(1) 主數(shù)據(jù)庫(kù):oracle_A;

(2) 從數(shù)據(jù)庫(kù):oracle_B;

在oracle_A中有一個(gè)表table_A與oracle_B中的表table_B結(jié)構(gòu)相同;

我是處在oracle_B,oracle_A數(shù)據(jù)庫(kù)分配給我有一個(gè)訪問(wèn)oracle_A表table_A的用戶,該用戶只擁有查詢的權(quán)限;

另外,需要說(shuō)明的一點(diǎn),就是在oracle_B處,只需對(duì)table_B表進(jìn)行查詢的操作,不進(jìn)行其他增刪改的操作。

場(chǎng)景介紹完了,我的問(wèn)題的是,如何在oracle_A中表table_A發(fā)生變化時(shí),實(shí)時(shí)更新同步到oracle_B的table_B中?

我原來(lái)的處理方式:

通過(guò)建立遠(yuǎn)程連接DBLink+JOB定時(shí)任務(wù)+存儲(chǔ)過(guò)程的方式,實(shí)現(xiàn)了定時(shí)同步更新,但不能做到實(shí)時(shí)同步。

三. 采用同義詞+DB_Link的方式結(jié)果步驟

之所以能夠選擇采用同義詞的方式,處理這個(gè)問(wèn)題。主要還是源于在問(wèn)題描述中提到一個(gè)點(diǎn),那就是我們只需要對(duì)同步后的表進(jìn)行查詢操作。這點(diǎn)是使用同義詞方式的重要要素。

下面詳細(xì)模擬一下整個(gè)實(shí)驗(yàn)測(cè)試的過(guò)程:

(1)首先在Oracle_A端創(chuàng)建一個(gè)對(duì)table_A只有查詢功能的用戶

1 創(chuàng)建用戶

sqlplus /nolog

conn /as sysdba;

create user username identified by password;

2 查看所有的用戶列表

用戶創(chuàng)建完成后,查看用戶是否創(chuàng)建成功

select * from all_users;

3授予權(quán)限

為了能夠保證能夠登陸,必須賦予如下權(quán)限

--授予username用戶創(chuàng)建session的權(quán)限,即登陸權(quán)限

grant create session to username;

--授予username用戶使用表空間的權(quán)限

grant unlimited tablespace to username;

--oracle對(duì)權(quán)限管理比較嚴(yán)謹(jǐn),普通用戶之間也是默認(rèn)不能互相訪問(wèn)的,需要互相授權(quán).

--如果scott用戶要授權(quán)給username用戶查看自己的test表的權(quán)限;

sqlplus scott/tiget@localhost:1521/orcl

--授予username用戶查看指定的權(quán)限

grant select on test to username;

--撤銷權(quán)限

基本語(yǔ)法同grant,關(guān)鍵字為revoke;

(2)驗(yàn)證用戶是否可以成功登錄,并進(jìn)行訪問(wèn)授權(quán)的表

--使用sqlplus登錄,并進(jìn)行查詢

sqlplus username/password@localhost:1521/orcl;

select * from scott.test;

注意:查詢表時(shí),務(wù)必帶上用戶名,說(shuō)明是哪個(gè)用戶下的表。

(3)創(chuàng)建遠(yuǎn)程連接DB_Link

1 創(chuàng)建遠(yuǎn)程連接 db_link

create public database link db32 connect to tianzhi_test identified by "tianzhi_test" using '192.168.56.6:1521/ORCL'

2 測(cè)試遠(yuǎn)程連接是否成功

select * from tianzhi_smart.zh_item_news@db32;

(4)在Oracle_B端創(chuàng)建同義詞

1 使用sqlplus登錄自己的用戶

sqlplus tianzhi_smart/tianzhi_smart@localhost:1521/orcl

2 創(chuàng)建同義詞

create or replace public synonym TEST1130 for scott.TEST@db32;

3 查詢測(cè)試

select * from TEST1130;

可以看到這與在Oracle_A源數(shù)據(jù)庫(kù)中查到的table_A表中的數(shù)據(jù)一樣.

注意事項(xiàng):

當(dāng)遠(yuǎn)程查詢的數(shù)據(jù)庫(kù)中包含BLOB字段時(shí),會(huì)報(bào)出如下錯(cuò)誤.

ORA-22992: 無(wú)法使用從遠(yuǎn)程表選擇的 LOB 定位器

當(dāng)出現(xiàn)這個(gè)錯(cuò)誤的時(shí)候,那是因?yàn)榭鐜?kù)連接查詢中的表中存在BLOB類型的字段,所以一定要注意,所有表中存在blob類型字段,

不能用 select * from 連接的表

不能將blob類型的字段出現(xiàn)在腳本中。

如果這些blob類型的字段一定要導(dǎo)過(guò)來(lái),可以先建立臨時(shí)表再插入本地表,方法如下.在pl/sql中執(zhí)行

第一步 建臨時(shí)表

create global temporary table foo ( X BLOB )

on commit delete rows;

第二步 插入本地表

insert into foo select blobcolumn from remoteTable@dl_remote ;

Oracle數(shù)據(jù)庫(kù),不同的數(shù)據(jù)庫(kù),如何把表結(jié)構(gòu)相同的數(shù)據(jù)從一個(gè)數(shù)據(jù)庫(kù)中導(dǎo)入至另一個(gè)數(shù)據(jù)庫(kù)?

這個(gè)是可以的,不過(guò)要有權(quán)限,首先創(chuàng)建一個(gè)DBLINK,讓數(shù)據(jù)庫(kù)可以互相關(guān)聯(lián),假設(shè)要把A用戶的a表數(shù)據(jù)復(fù)制給B用戶b表就讓B賦予連接A的權(quán)限,然后寫(xiě)SQL語(yǔ)句:INSERT INTO B.b (SELECT * FROM A.a); ?這樣就可以了。


網(wǎng)站欄目:oracle怎么跨數(shù)據(jù)庫(kù),oracle跨數(shù)據(jù)庫(kù)查詢數(shù)據(jù)
轉(zhuǎn)載注明:http://weahome.cn/article/dsgicoc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部