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


    Oracle数据库环境存在两个数据库版本12C及19C,在执行一些操作时需要设置对应版本的环境变量
    计划登录12C环境,于是按如下方式设置环境变量

    export ORACLE_BASE=/u01/app/oracle
    export ORACLE_HOME=$ORACLE_HOME/product/12.2.0/dbhome_1
    export ORACLE_SID=db12c
    
    • 1
    • 2
    • 3

    可是通过sqlplus登陆后却显示19C版本信息
    针对这个问题,最开始的方式是在root中修改bash_profile文件,然后登录到oracle用户,很是麻烦
    后面一直寻找更简单的方式,通过which查看sqlplus使用的是哪个

    which sqlplus
    /u01/app/oracle/product/19.3.0/dbhome_1/bin/sqlplus
    
    • 1
    • 2

    此时考虑which命令是根据什么寻找到这个sqlplus的
    通过查阅资料获取如下信息

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

    查看当前PATH信息

    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/:
    
    • 1
    • 2

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

    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:.
    
    • 1
    • 2
    • 3
    • 4
    • 5

    顺利通过测试
    再尝试一次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:.
    
    • 1
    • 2
    • 3
    • 4
    • 5

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

    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:.
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

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

  • 相关阅读:
    【附源码】计算机毕业设计JAVA疫情期间物资分派管理系统
    撬动农业价值天平,拼多多凭什么?
    在工业设计在线应用中,这些词你知道吗?
    参数校验与国际化:提高代码稳定性和可维护性的重要方法
    Linux 代理服务器 squid 安装和使用 [正向代理]
    国产麒麟、uos在线编辑word文件并控制编辑区域(局部编辑)
    TorchDrug教程--预训练的分子表示
    如何使用 VuePress 搭建博客网站并 Vercel 部署
    【C/PTA】函数专项练习(一)
    快收藏!最全GO语言实现设计模式【下】
  • 原文地址:https://blog.csdn.net/u014650965/article/details/134542749