1.安裝oracle 11g
創(chuàng)新互聯(lián)公司專(zhuān)業(yè)提供成都服務(wù)器托管服務(wù),為用戶(hù)提供五星數(shù)據(jù)中心、電信、雙線接入解決方案,用戶(hù)可自行在線購(gòu)買(mǎi)成都服務(wù)器托管服務(wù),并享受7*24小時(shí)金牌售后服務(wù)。
2.Oracle自帶的SQL Developer
在安裝完Oracle Database 11g Release 2數(shù)據(jù)庫(kù),想試一下Oracle自帶的SQL DeveloperW工具,在操作系統(tǒng)菜單的所有程序中找到SQL Developer如下所示,并單擊:
結(jié)果卻提示缺少快捷方式,沒(méi)找到“SQLDEVELOPER.BAT”,**
在Oracle的安裝目錄D:\DataBaseInstall\Oralce_11g_r2\product\11.2.0\dbhome_1\sqldeveloper\sqldeveloper\bin下的確也沒(méi)找到sqldeveloper.bat文件。網(wǎng)上很多人都說(shuō)重新下載SQL Developer替換掉安裝Oracle時(shí)自帶的那個(gè)。
重新到Oracle官網(wǎng)下載SQL Developer,當(dāng)前最新版下載地址:
將下載下來(lái)的 sqldeveloper64-3.2.20.09.87-no-jre.zip解壓到Oracle安裝目錄下
這時(shí)重新單擊操作系統(tǒng)菜單中的“SQL Developer”,看到命令窗口閃一下就消失了??戳艘幌耂QL Developer的“readme.html”文檔知道了SQL Developer 3.2支持的Java版本至少要1.6.0_04。
那就下載當(dāng)前最新JDK安裝,在這里我下載的是jrockit-jdk1.6.0_37-R28.2.5-4.1.0-windows-x64.exe。下載完成后雙擊出現(xiàn)如下安裝界面:
在歡迎窗口中單擊“Next”:
設(shè)置JDK安裝目錄,單擊“Next”:
這里問(wèn)你是否需要安裝示例或源代碼,根據(jù)需要選擇,這里我就不選了直接單擊“Next”:
這里是否安裝JRE,選擇“Yes”,單擊“Next”:
設(shè)置JRE安裝目錄,單擊“Next”:
安裝過(guò)程:
安裝完畢,單擊“Done”關(guān)閉。
現(xiàn)在新的JDK安裝完后,重新單擊操作系統(tǒng)菜單中的“SQL Developer”,這時(shí)“SQL Developer”可以啟動(dòng),但是報(bào)了如下的異常:
Exception initializing 'oracle.dbtools.raptor.plsql.PLSQLAddin' in extension 'Or
acle SQL Developer': java.lang.NoClassDefFoundError: com/sun/jdi/Bootstrap
at oracle.jdevimpl.debugger.jdi.DebugJDIConnector.getVersion(DebugJDICon
nector.java:30)
at oracle.jdevimpl.debugger.support.DebugFactory.(DebugFactory.j
ava:81)
at oracle.dbtools.raptor.plsql.PLSQLAddin.initialize(PLSQLAddin.java:97)
at oracle.ideimpl.extension.AddinManagerImpl.initializeAddin(AddinManage
rImpl.java:407)
at oracle.ideimpl.extension.AddinManagerImpl.initializeAddins(AddinManag
erImpl.java:214)
at oracle.ideimpl.extension.AddinManagerImpl.initProductAndUserAddins(Ad
dinManagerImpl.java:128)
at oracle.ide.IdeCore.initProductAndUserAddins(IdeCore.java:1941)
at oracle.ide.IdeCore.startupImpl(IdeCore.java:1565)
at oracle.ide.Ide.startup(Ide.java:703)
at oracle.ideimpl.DefaultIdeStarter.startIde(DefaultIdeStarter.java:35)
at oracle.ideimpl.Main.start(Main.java:184)
at oracle.ideimpl.Main.main(Main.java:146)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.
java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces
sorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at oracle.ide.boot.PCLMain.callMain(PCLMain.java:62)
at oracle.ide.boot.PCLMain.main(PCLMain.java:54)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodA
ccessorImpl. java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces sorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at oracle.classloader.util.MainClass.invoke(MainClass.java:128) at oracle.ide.boot.IdeLauncher.bootClassLoadersAndMain(IdeLauncher.java: 189) at oracle.ide.boot.IdeLauncher.launchImpl(IdeLauncher.java:89) at oracle.ide.boot.IdeLauncher.launch(IdeLauncher.java:65) at oracle.ide.boot.IdeLauncher.main(IdeLauncher.java:54) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl. java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces sorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at oracle.ide.boot.Launcher.invokeMain(Launcher.java:713) at oracle.ide.boot.Launcher.launchImpl(Launcher.java:115) at oracle.ide.boot.Launcher.launch(Launcher.java:68) at oracle.ide.boot.Launcher.main(Launcher.java:57)
看著異常就不爽啊,解決唄。運(yùn)行命令行窗口查看是否設(shè)置了JDK系統(tǒng)環(huán)境變量,這里顯然是沒(méi)有設(shè)置JDK系統(tǒng)環(huán)境變量:
設(shè)置系統(tǒng)環(huán)境變量
在桌面選中“計(jì)算機(jī)”右鍵選擇“屬性”,單擊“高級(jí)系統(tǒng)設(shè)置”:
在高級(jí)選項(xiàng)卡中單擊“環(huán)境變量”:
在系統(tǒng)變量下單擊“新建”,填入變量名“JAVA_HOME”,變量值為JDK的安裝目錄,我這里為“ D:\JAVAEEServiceInstall\Java\jrockit-jdk1.6.0_37-R28.2.5-4.1.0 ”,單擊“確定”:
在系統(tǒng)變量中找到“Path”,單擊“編輯”,在變量值中加入“%JAVA_HOME%\bin”以“;”相隔,單擊“確定”:
系統(tǒng)環(huán)境變量設(shè)置完成后,重新啟動(dòng)命令行窗口,檢查是否成功。如下為設(shè)置成功:
重新單擊操作系統(tǒng)菜單中的“SQL Developer”,這時(shí)“SQL Developer”可以正常啟動(dòng):
如果希望不出現(xiàn)“[WARN ][jrockit] MaxPermSize=128M ignored: Not a valid option for JRockit”警告,那用記事本打開(kāi)SQL Developer的bin目錄下的“sqldeveloper.bat”文件,找到“-XX:MaxPermSize=128M”直接刪除。因?yàn)閖rockit已經(jīng)不需要-XX:MaxPermSize這樣的參數(shù)了。
注:1.JDK一定要是1.6版本的即U6版本。
2.發(fā)現(xiàn)SQL_developer還是會(huì)一閃而過(guò),但是SQL_developerW可以方面使用。
3.Oracle SQL Developer 添加SQLServer 和Sybase 連接
1. 開(kāi)始只有oracle 和access 連接
\
喎?"/kf/ware/vc/" target="_blank" class="keylink"vcD4KPHA+CjxzdHJvbmc+Mi4gtPK/qk9yYWNsZSBTUUwgRGV2ZWxvcGVyo7o8L3N0cm9uZz48L3A+CjxwPgo8c3Ryb25nPrmkvt+hqqGqPHN0cm9uZz4mZ3Q7PC9zdHJvbmc+ytfRoc/uoaqhqjxzdHJvbmc+Jmd0Ozwvc3Ryb25nPsr9vt2/4qGqoaomZ3Q7tdrI/be9SkRCQ8f9tq+zzNDyoaqhqiZndDvM7bzTx/22r8z1xL88L3N0cm9uZz48YnI+CjwvcD4KPHA+CjxpbWcgc3JjPQ=="/uploadfile/Collfiles/20160421/20160421091223242.jpg" alt="\"
\
3. 自動(dòng)加載到目錄,JTDS.jar 下載后就到放這里。
(我的路徑:C:\Documents and Settings\Administrator\Application Data\SQL Developer\)
我的JTDS.jar免費(fèi)下載地址:
\
4. 完成后添加連接有SQLServer 和Sybase了。
\
---------------------------------------------------------------------------------
---------------------------------------------------------------------------------
還有一種添加方法是:
1. 幫助——檢查更新
\
2. 選擇可更新的相關(guān)軟件查件
\
3. 單擊下一步自動(dòng)更新,則出現(xiàn)下列詳細(xì)插件,選取JTDS JDBC Driver……
\
\
4. 填寫(xiě)在官方網(wǎng)址上的賬戶(hù)信息,確定。
\
4.sqlserver 轉(zhuǎn)oracle
上一次,我使用手工轉(zhuǎn)換SQL腳本的方式進(jìn)行數(shù)據(jù)庫(kù)的遷移,其間過(guò)程相當(dāng)繁瑣,特別是標(biāo)識(shí)符長(zhǎng)度的限制讓我焦頭爛額,因?yàn)槲覀兊南到y(tǒng)中長(zhǎng)標(biāo)識(shí)符真是多如繁星,另外,表結(jié)構(gòu)建好之后,數(shù)據(jù)的遷移又是一個(gè)相當(dāng)復(fù)雜的過(guò)程,因?yàn)樾薷牧瞬簧俚谋砻枰褜?dǎo)出的數(shù)據(jù)和表一一對(duì)應(yīng)上。
但是,除了手工的方式之外,其實(shí)我們還有更為簡(jiǎn)便和自動(dòng)化的解決方案,那就是ORACLE官方提供的Sql Developer自帶的Oracle Migration Workbench。
什么是Oracle SQL Developer?在官方頁(yè)面上,是這樣介紹它的:
Oracle SQL Developer is a free and fully supported graphical tool for database development. With SQL Developer, you can browse database objects, run SQL statements and SQL scripts, and edit and debug PL/SQL statements. You can also run any number of provided reports, as well as create and save your own. SQL Developer enhances productivity and simplifies your database development tasks .
另外,通過(guò)第三方驅(qū)動(dòng)包,該工具還支持連接和管理各種主流數(shù)據(jù)庫(kù)服務(wù)器。
下面就把我使用這個(gè)工具遷移Microsoft SQL Server 2008數(shù)據(jù)庫(kù)到Oracle 11G的過(guò)程記錄下來(lái),為了積累也為分享。
第一部分:獲取工具
第二部分:建立資料檔案庫(kù)(Migration Repository)
第三部分:數(shù)據(jù)庫(kù)移植向?qū)?/p>
第四部分:SqlServer中的架構(gòu)到Oracle中的模式,名稱(chēng)的處理
第五部分:轉(zhuǎn)移數(shù)據(jù)
第六部分:存儲(chǔ)過(guò)程和函數(shù)
首先,當(dāng)然是獲得工具,該工具在Oracle Sql Developer官方下載頁(yè)面里面可以直接下載到。Windows 32位直連地址:Windows 32bit Sql Developer。Oracle Sql Developer需要JDK的支持,在下載頁(yè)面中提供了包含JDK的下載包,還有支持各種操作系統(tǒng)的下載選項(xiàng)。
下載后,解壓到任意位置。直接運(yùn)行程序。第一次運(yùn)行,需要指定JDK的目錄。
啟動(dòng)后,我們要做的第一件事,不干別的,先下載SQL SERVER的驅(qū)動(dòng)程序。點(diǎn)擊菜單幫助,選擇檢查更新,彈出檢查更新向?qū)Т翱?,第一?yè)一般是廢話,直接下一步,等更新中心列表加載完畢后,只選擇“Third Party SQL Developer extensions”,點(diǎn)擊下一步,等待更新搜索完畢后,中列表中找到并選中 JTDS JDBC Driver,如下圖:
image
下一步,在許可協(xié)議頁(yè)面,點(diǎn)擊“我同意”按鈕后再點(diǎn)下一步,等下載完畢后關(guān)閉窗口,彈出提示需要重啟程序才能完成更新,點(diǎn)擊“是”。等程序重啟完畢。
環(huán)境準(zhǔn)備完畢,開(kāi)始進(jìn)入到正題移植數(shù)據(jù)庫(kù)。
建立資料檔案庫(kù)(Migration Repository)
一、連接到Oracle
在程序左邊的連接窗口中,點(diǎn)擊加號(hào)按鈕,添加一個(gè)到Oracle數(shù)據(jù)庫(kù)的dba連接,如下圖:
image
配置完成后,點(diǎn)擊連接按鈕,連接到數(shù)據(jù)庫(kù)。
二,建立用戶(hù)
打開(kāi)到Oracle數(shù)據(jù)的連接,新建一個(gè)用戶(hù),我們要在該用戶(hù)的模式中建立所謂的“資料檔案庫(kù)”,并使用該用戶(hù)去建立SQL Server移植后的用戶(hù)名,以及做其它的一些工作。按照幫助中的說(shuō)明,這個(gè)用戶(hù)最少需要以下權(quán)限和角色:
Roles
CONNECT WITH ADMIN OPTION,RESOURCE WITH ADMIN OPTION
Privileges
ALTER ANY ROLE,ALTER ANY SEQUENCE,ALTER ANY TABLE,ALTER TABLESPACE,ALTER ANY TRIGGER,COMMENT ANY TABLE,CREATE ANY SEQUENCE,CREATE ANY TABLE,CREATE ANY TRIGGER,CREATE VIEW WITH ADMIN OPTION,CREATE PUBLIC SYNONYM WITH ADMIN OPTION,CREATE ROLE
CREATE USER,DROP ANY SEQUENCE,DROP ANY TABLE,DROP ANY TRIGGER,DROP USER,DROP ANY ROLE,GRANT ANY ROLE,INSERT ANY TABLE,SELECT ANY TABLE,UPDATE ANY TABLE
以下語(yǔ)句直接建立一個(gè)名為migrations的用戶(hù):
-- Create the user
create user MIGRATIONS
identified by MIGRATIONS
default tablespace USERS
temporary tablespace TEMP
profile DEFAULT;
-- Grant/Revoke role privileges
grant connect to MIGRATIONS with admin option;
grant resource to MIGRATIONS with admin option;
-- Grant/Revoke system privileges
grant alter any role to MIGRATIONS;
grant alter any sequence to MIGRATIONS;
grant alter any table to MIGRATIONS;
grant alter any trigger to MIGRATIONS;
grant alter tablespace to MIGRATIONS;
grant comment any table to MIGRATIONS;
grant create any sequence to MIGRATIONS;
grant create any table to MIGRATIONS;
grant create any trigger to MIGRATIONS;
grant create any view to MIGRATIONS;
grant create materialized view to MIGRATIONS with admin option;
grant create public synonym to MIGRATIONS with admin option;
grant create role to MIGRATIONS;
grant create session to MIGRATIONS with admin option;
grant create synonym to MIGRATIONS with admin option;
grant create tablespace to MIGRATIONS;
grant create user to MIGRATIONS;
grant create view to MIGRATIONS with admin option;
grant drop any role to MIGRATIONS;
grant drop any sequence to MIGRATIONS;
grant drop any table to MIGRATIONS;
grant drop any trigger to MIGRATIONS;
grant drop tablespace to MIGRATIONS;
grant drop user to MIGRATIONS;
grant grant any role to MIGRATIONS;
grant insert any table to MIGRATIONS;
grant select any table to MIGRATIONS;
grant unlimited tablespace to MIGRATIONS with admin option;
grant update any table to MIGRATIONS;
再次點(diǎn)擊連接中的加號(hào)按鈕,添加一個(gè)使用剛剛新建立的用戶(hù)的連接。
image
連接后,在該連接上點(diǎn)擊右鍵,選擇移植資料檔案庫(kù)-關(guān)聯(lián)移植資料檔案庫(kù),程序會(huì)在該用戶(hù)下建立移植資料檔案庫(kù)所需要的表、存儲(chǔ)過(guò)程等等,彈出一個(gè)對(duì)話框顯示當(dāng)前建立的進(jìn)度,稍等片刻即建立完畢。
數(shù)據(jù)庫(kù)移植向?qū)?/p>
一,建立到源SqlServer數(shù)據(jù)庫(kù)的連接
在連接窗口中,點(diǎn)擊綠色加號(hào)按鈕,打開(kāi)連接配置窗口,按下圖建立到SqlServer的連接:
image
因?yàn)閯?dòng)態(tài)商品的使用,使得原來(lái)SqlServer配置頁(yè)中默認(rèn)的1433往往沒(méi)有辦法連接到SqlServer2008數(shù)據(jù)庫(kù),修改為1434即可。
二、啟動(dòng)數(shù)據(jù)庫(kù)移植向?qū)?/p>
建立到SqlServer的連接后,開(kāi)始對(duì)數(shù)據(jù)庫(kù)進(jìn)行移植。有兩個(gè)地方可以啟動(dòng)數(shù)據(jù)庫(kù)移植向?qū)?,一個(gè)是在新建的SqlServer連接上點(diǎn)擊右鍵,選擇移植到Oracle,另一個(gè)是在菜單工具-移植-移植,啟動(dòng)向?qū)Ш螅谝豁?yè)當(dāng)然是向?qū)У暮?jiǎn)介,通過(guò)簡(jiǎn)介,我們可以知道整個(gè)移植過(guò)程有7步,并且有兩個(gè)先決條件,如下圖:
image
直接點(diǎn)擊下一步。
三、選擇資料檔案庫(kù)
在這個(gè)頁(yè)面中,我們也可以去建立連接和資料檔案庫(kù),也就是前一部分中我們所做的工作在這里也可以進(jìn)行。當(dāng)然選擇我們剛剛建立的migrations連接,如下圖:
image
這里截?cái)嗟囊馑际菍①Y料檔案庫(kù)清空,我們建立一個(gè)移植項(xiàng)目后,所有抓取的數(shù)據(jù)庫(kù)結(jié)構(gòu)信息、統(tǒng)計(jì)信息還有轉(zhuǎn)換記錄等都保存在這個(gè)資料檔案庫(kù)中,只要項(xiàng)目名稱(chēng)不同,即使不清空資料檔案庫(kù)也不會(huì)影響到移植工作。當(dāng)然,如果希望更“清爽”一點(diǎn),也可以勾選。這是后話。
四、為轉(zhuǎn)換項(xiàng)目命名
選擇好資料檔案庫(kù)后,點(diǎn)擊下一步,為我們的轉(zhuǎn)換項(xiàng)目輸入名稱(chēng)和備注,以便識(shí)別。另外,還需要指定腳本生成目錄,用于存放向?qū)?zhí)行過(guò)程中生成的腳本。
五、選擇源數(shù)據(jù)庫(kù)連接
然后繼續(xù)下一步,選擇源數(shù)據(jù)庫(kù),在這里有聯(lián)機(jī)和離線兩種模式,聯(lián)機(jī)即是直接連接到源數(shù)據(jù)進(jìn)行抓取,而離線則是在SqlDeveloper不直接連接到源數(shù)據(jù)庫(kù)的情況下,通過(guò)SqlDeveloper提供的腳本預(yù)先捕獲數(shù)據(jù)庫(kù),得到數(shù)據(jù)庫(kù)結(jié)構(gòu)文件后,通過(guò)向?qū)?dǎo)入。
這里當(dāng)然是選擇我們剛才建立的SqlServer連接。
六、選擇捕獲源數(shù)據(jù)庫(kù)
linux下使用export ORACLE_BASE=/u01/app/oracle。
window下應(yīng)該使用set ORACLE_BASE=/u01/app/oracle,但是window下一般都不用設(shè)置。
首先是ORACLE_HOME,這個(gè)環(huán)境配置與java的環(huán)境培訓(xùn)類(lèi)似,如下圖按照計(jì)算機(jī)右擊-》高級(jí)系統(tǒng)設(shè)置-》高級(jí)-》環(huán)境變量-》在系統(tǒng)變量中新建