被环境变量虐过一遍获得的启示

Oracle数据库环境存在两个数据库版本12C及19C,在执行一些操作时需要设置对应版本的环境变量

计划登录12C环境,于是按如下方式设置环境变量

bash 复制代码
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_HOME/product/12.2.0/dbhome_1
export ORACLE_SID=db12c

可是通过sqlplus登陆后却显示19C版本信息

针对这个问题,最开始的方式是在root中修改bash_profile文件,然后登录到oracle用户,很是麻烦

后面一直寻找更简单的方式,通过which查看sqlplus使用的是哪个

bash 复制代码
which sqlplus
/u01/app/oracle/product/19.3.0/dbhome_1/bin/sqlplus

此时考虑which命令是根据什么寻找到这个sqlplus的

通过查阅资料获取如下信息

which指令会在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。

查看当前PATH信息

bash 复制代码
echo $PATH
/opt/java/jdk1.8.0_231/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/u03/app/oracle/product/19.3.0/dbhome_1/bin/:/usr/local/python3/bin:/root/bin:/u02/app/oracle/product/12.2.0/dbhome_1/bin/:

里面有两个Oracle的路径,第一个是19C,第二个是12C

这说明which在查找到19C的环境变量后就直接使用了,没有再往后找,那操作系统也应该是这个思路,索性我直接修改PATH的信息

bash 复制代码
export PATH=/opt/java/jdk1.8.0_231/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/local/python3/bin:/root/bin:
export ORACLE_BASE=/u02/app/oracle/
export ORACLE_HOME=$ORACLE_BASE/product/12.2.0/dbhome_1/bin/
export ORACLE_SID=db12c
export PATH=$PATH:$ORACLE_HOMME/bin:.

顺利通过测试

再尝试一次19C

bash 复制代码
export PATH=/opt/java/jdk1.8.0_231/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/local/python3/bin:/root/bin:
export ORACLE_BASE=/u03/app/oracle/
export ORACLE_HOME=$ORACLE_BASE/product/19.3.0/dbhome_1/bin/
export ORACLE_SID=db19c
export PATH=$PATH:$ORACLE_HOMME/bin:.

通过测试

将这两个环境变量写入文件,直接调用

bash 复制代码
vim .bash_profile_12C
export PATH=/opt/java/jdk1.8.0_231/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/local/python3/bin:/root/bin:
export ORACLE_BASE=/u02/app/oracle/
export ORACLE_HOME=$ORACLE_BASE/product/12.2.0/dbhome_1/bin/
export ORACLE_SID=db12c
export PATH=$PATH:$ORACLE_HOMME/bin:.

vim .bash_profile_19C
export PATH=/opt/java/jdk1.8.0_231/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/local/python3/bin:/root/bin:
export ORACLE_BASE=/u03/app/oracle/
export ORACLE_HOME=$ORACLE_BASE/product/19.3.0/dbhome_1/bin/
export ORACLE_SID=db19c
export PATH=$PATH:$ORACLE_HOMME/bin:.

直接调用即可,长舒一口气,不知道大家还有没有更好的办法

相关推荐
梓仁沐白几秒前
操作系统:进程通信和死锁
linux·服务器·网络
爱吃番茄鼠骗20 分钟前
Linux操作系统———守护进程
linux
Nerd Nirvana28 分钟前
IPv6组播在DLMS协议中的应用——基础知识掌握
linux·运维·服务器·网络·网络协议·ipv6·dlms协议
福尔摩斯张32 分钟前
TCP/IP网络编程深度解析:从Socket基础到高性能服务器构建(超详细)
linux·运维·服务器·开发语言·网络·网络协议·tcp/ip
Sleepy MargulisItG32 分钟前
【Linux网络编程】传输层协议:TCP
linux·网络·tcp/ip
卡布叻_星星33 分钟前
Docker之Windows与Linux不同架构部署理解
linux·windows·docker
Cat God 00744 分钟前
基于 CentOS 7.6 的 MySQL 8.0 主从复制
linux·服务器·mysql·centos
春日见1 小时前
如何跑通,吃透一个开源项目?
linux·运维·开发语言·数码相机·matlab
用户6135411460161 小时前
【麒麟Kylin】cmake-3.16.5 rpm包安装步骤详解 附常见问题
linux
AAA_bo11 小时前
liunx安装canda、python、nodejs、git,随后部署私有网页内容提取工具--JinaReader全攻略
linux·python·ubuntu·typescript·aigc·python3.11·jina