网站首页 > 技术文章 正文
APEX环境的迁移往往涉及三个方面:
- 业务数据的迁移,一般是业务数据相关Schema的导入导出,如使用工具expdp/impdp等
- 目标环境APEX的安装,迁移时一般会在目标环境下安装最新的APEX版本
- APEX工作区及下面所有应用的迁移
第一点主要是DBA的工作,也有成熟的工具可用。第二点主要就是一个APEX的安装过程。这里主要记录第三点:
关于工作区的导出,可以直接在界面上操作,将整个工作区配置导出来,然后再导入到目标APEX环境就可以了,这点相当于直接在界面上点一下导出、导入,非常简单。但是,导出工作区并不会将下面的应用导出来。虽然应用也可以在界面上逐个导出,但如果应用很多那就很麻烦。
Oracle提供了一个很好用的工具SQLcl,相当于SQL Developer的命令行版本,直接减压即可(依赖于java11+,所以可能提前安装java 17即可,并设置一下JAVA_HOME和PATH环境变量)。目标环境下工作区创建或导入后,就可以迁移应用了。
一次性导出所有应用的脚本 (export_all_apps.sh):
#!/bin/sh
DB_CONNECTION=testuser/MyPassword123@192.168.1.9:1521/PDB1.mydb.com #数据库连接
WSID=12290542509412485 #工作区ID,在界面上【关于】菜单里面有
EXP_DIR=./apex_apps #应用导出位置,它是相对目录,相对于当前执行命令的目录
sql $DB_CONNECTION << EOF
apex export -workspaceid $WSID -dir $EXP_DIR -expPubReports -expSavedReports -expSupportingObjects Y -expType APPLICATION_SOURCE
EOF
导入单个应用的脚本 (import_apex_app.sh)
#!/bin/sh
WORKSPACE=$1
APPID=$2
IMP_DIR=$3
DB_CONNECTION=$4
sql $DB_CONNECTION << EOF
echo '*** Setting parameters ...'
begin
apex_application_install.set_workspace_id($WORKSPACE);
apex_application_install.set_application_id($APPID);
apex_application_install.generate_offset;
apex_application_install.set_auto_install_sup_obj( p_auto_install_sup_obj => true );
end;
/
echo '*** Importing the application f$APPID.sql'
@$IMP_DIR/f$APPID.sql
echo '*** Importing the application f$APPID.sql...[Done]'
EOF
一次性导入所有应用的脚本(import_all_apps.sh,它会循环调用导入单个应用的脚本import_apex_app.sh)
#!/bin/sh
DB_CONNECTION=testuser/MyPassword123@192.168.1.10:1521/PDB1.mydb.com #数据库连接
IMP_DIR=./apex_apps #之前应用导出的位置,它是相对目录,相对于当前执行命令的目录
WORKSPACE=11174905805663674 #工作区ID,在界面上【关于】菜单里面有
apps=$(ls $IMP_DIR)
for app in $apps
do
appid=$(echo $app | sed 's/^f//' | sed 's/\.sql//')
./import_apex_app.sh $WORKSPACE $appid $IMP_DIR $DB_CONNECTION
done
猜你喜欢
- 2024-10-25 Oracle向量数据类型及数据加载 oracle中数据类型
你 发表评论:
欢迎- 630℃几个Oracle空值处理函数 oracle处理null值的函数
- 623℃Oracle分析函数之Lag和Lead()使用
- 612℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 606℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 604℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 596℃【数据统计分析】详解Oracle分组函数之CUBE
- 586℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 570℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- oracle 19cOCM认证有哪些内容(oracle认证ocm月薪)
- Oracle新出AI课程认证,转型要持续学习
- oracle 表的查询join顺序,可能会影响查询效率
- Oracle DatabaseAmazon Web Services正式可用,Oracle数据库上云更容易了
- Oracle 19.28 RU 升级最佳实践指南
- 汉得信息:发布EBS系统安装启用JWS的高效解决方案
- 如何主导设计一个亿级高并发系统架构-数据存储架构(三)
- Java 后端开发必看!工厂设计模式轻松拿捏
- ORA-00600 「25027」 「x」报错(抱错孩子电视剧 爸爸是武术 另一个爸爸是画家)
- 新项目终于用上了jdk24(jdk新建项目)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)