①安装oracle 11g
结果却提示缺少快捷方式,没找到"SQLDEVELOPER.BAT",**
在欢迎窗口中单击"Next":
设置JDK安装目录,单击"Next":
这里问你是否需要安装示例或源代码,根据需要选择,这里我就不选了直接单击"Next":
这里是否安装JRE,选择"Yes",单击"Next":
设置JRE安装目录,单击"Next":
安装过程:
安装完毕,单击"Done"关闭.
现在新的JDK安装完后,重新单击操作系统菜单中的"SQL Developer",这时"SQL Developer"可以启动,但是报了如下的异常:
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
at oracle.jdevimpl.debugger.support.DebugFactory.(DebugFactory.j
at oracle.ideimpl.extension.AddinManagerImpl.initializeAddin(AddinManage
at oracle.ideimpl.extension.AddinManagerImpl.initializeAddins(AddinManag
at oracle.ideimpl.extension.AddinManagerImpl.initProductAndUserAddins(Ad
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodA
看着异常就不爽啊,解决呗.运行命令行窗口查看是否设置了JDK系统环境变量,这里显然是没有设置JDK系统环境变量:
设置系统环境变量
在桌面选中"计算机"右键选择"属性",单击"高级系统设置":
在高级选项卡中单击"环境变量":
系统环境变量设置完成后,重新启动命令行窗口,检查是否成功.如下为设置成功:
重新单击操作系统菜单中的"SQL Developer",这时"SQL Developer"可以正常启动:
① 开始只有oracle 和access 连接
\
(我的路径:C:\Documents and Settings\Administrator\Application Data\SQL Developer\)
---------------------------------------------------------------------------------
还有一种添加方法是:
① 帮助——检查更新
上一次,我使用手工转换SQL脚本的方式进行数据库的迁移,其间过程相当繁琐,特别是标识符长度的限制让我焦头烂额,因为我们的系统中长标识符真是多如繁星,另外,表结构建好之后,数据的迁移又是一个相当复杂的过程,因为修改了不少的表名,需要把导出的数据和表一一对应上.
但是,除了手工的方式之外,其实我们还有更为简便和自动化的解决方案,那就是ORACLE官方提供的Sql Developer自带的Oracle Migration Workbench.
什么是Oracle SQL Developer?在官方页面上,是这样介绍它的:
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 .
另外,通过第三方驱动包,该工具还支持连接和管理各种主流数据库服务器.
第一部分:获取工具
第二部分:建立资料档案库(Migration Repository)
第三部分:数据库移植向导
第四部分:SqlServer中的架构到Oracle中的模式,名称的处理
第五部分:转移数据
第六部分:存储过程和函数
image
环境准备完毕,开始进入到正题移植数据库.
建立资料档案库(Migration Repository)
第一段:连接到Oracle
二,建立用户
打开到Oracle数据的连接,新建一个用户,我们要在该用户的模式中建立所谓的"资料档案库",并使用该用户去建立SQL Server移植后的用户名,以及做其它的一些工作.按照帮助中的说明,这个用户最少需要以下权限和角色:
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
以下语句直接建立一个名为migrations的用户:
-- 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;
数据库移植向导
一,建立到源SqlServer数据库的连接
第二段:启动数据库移植向导
第三段:选择资料档案库
在这个页面中,我们也可以去建立连接和资料档案库,也就是前一部分中我们所做的工作今天这一节也可以进行.当然选择我们刚刚建立的migrations连接,如下图:
这里截断的意思是将资料档案库清空,我们建立一个移植项目后,所有抓取的数据库结构信息、统计信息还有转换记录等都保存在这个资料档案库中,只要项目名称不同,即使不清空资料档案库也不会影响到移植工作.当然,如果希望更"清爽"一点,也可以勾选.这是后话.
第四段:为转换项目命名
第五段:选择源数据库连接
然后继续下一步,选择源数据库,今天这一节有联机和离线两种模式,联机即是直接连接到源数据进行抓取,而离线则是在SqlDeveloper不直接连接到源数据库的情况下,通过SqlDeveloper提供的脚本预先捕获数据库,得到数据库结构文件后,通过向导导入.
这里当然是选择我们刚才建立的SqlServer连接.
第六段:选择捕获源数据库
在建立了Oracle数据库之后,为了使得客户应用可以访问特定数据库,必须要在监听程序中追加该数据库.一个监听程序可以监听多个Oracle数据库,多个监听程序也可以监听同一个数据库.但是监听程序只能用于同一台服务器上的Oracle数据库.安装了Oracle时,会自动建立默认的监听程序LISTENER.一般只需要将需要使用的数据库追加到这个监听程序上就可以了.
保存了监听程序配置之后,必须要重新启动监听程序才能生效.windows中可以在"服务"中重新启动.
经过以上分析,你是不是明白ORACLE 的 NET MANAGER是怎么一回事了呢?