上一篇博文介绍了关于.bashrc和.bash_profile的相关知识,在oracle的用户设置中能发挥作用。

场景:上周准备学习一下oracle,下载了安装文件后,在linux上新建了一个用户oracle,然后在这个用户下面安装的。也不太记得当时什么情况了,前些天通过oracle系统提供的sqlplus访问,一切正常。今天我想通过终端su到oracle用户下,然后用sqlplus命令打开sqlplus,遇到了不少问题,这里做一个总结。

1. oracle用户密码忘记了。

这个比较容易,打开terminal,登录到root用户下,更改oracle用户密码。

[root@win ~]# passwd oracle

2. 修改密码,登录后问题就多了,发现bash中不会显示成 [oracle@win ~] 这样的模式,而是 bash-4.1$。输入任何命令都不能运行,当然输入sqlplus也不行,提示找不到命令。

查看oracle用户的HOME目录,上一篇文章提到了怎么查找,因为登录后任何命令都不能执行,所以不能通过命令来获取,要手动查。

查看得知HOME=/u01/app/oracle

查看此目录下的文件,发现没有.bashrc 和 .bash_profile文件,也就是说,没有设置任何环境变量与bash配置,当然不可能找到任何命令。

解决方法:

从其他用户那儿拷贝这两个文件,当然如果你非常熟悉的话也可以自己编写,不过建议拷贝过来做修改。

我从Jack用户那儿拷来了这两个文件,将它们放在了oracle home目录下。应用这两个脚本:

bash-4.1 $  source .bashrc
bash-4.1 $ source .bash_profile

执行后,bash中就显示成 [oracle@win~] 这样的形式了。这是因为之前没有设置任何变量,执行脚本后,设置了SP1变量,显示恢复正常。

此时常用的命令也可以执行了。

3. 现在的问题就剩下这个了,网上有不少人讨论的,输入sqlplus后提示命令找不到。

这种情况就是要环境变量的设置问题了。前一篇文章中已经提到了,我们可以在.bashrc中进行配置,一定会在bash启动时执行。最终的bash设置如下:

[oracle@win ~]$ cat .bashrc
# .bashrc # Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi # User specific aliases and functions ORACLE_BASE=/u01/app ORACLE_HOME=$ORACLE_BASE/oracle/product/11.2./xe ORACLE_SID=XE PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin export PATH ORACLE_BASE ORACLE_HOME ORACLE_SID

这里设置了四个环境变量,分别是:ORACLE_BASE, ORACLE_HOME, ORACLE_SIDPATH

在设置这些环境变量的过程中出现了三个问题。

1. SP2-0750: you may need to set ORACLE_HOME to your Oracle software directory

由于我没有设置ORACLE_HOME环境变量,注意这里选择oracle内bin前面的路径就好了。

ORACLE_HOME=$ORACLE_BASE/oracle/product/11.2./xe

 2. ORA-12162: TNS:net service name is incorrectly specified

这个错误是由于没有设置ORACLE_SID环境变量导致。查询ORACLE_SID的方法如下:

SQL> select instance_name from v$instance;

INSTANCE_NAME
----------------
XE

我们根据这个设置ORACLE_SID环境变量。

ORACLE_SID=XE

3. 明明我在另一个sqlplus中已经启动了数据库,可是在这个bash中连接时却提示:“Connected to an idle instance. ” ,即不能登陆到数据库中 。

此时,所有的环境变量我已经设置好了,PATH设置好了,sqlplus命令正常执行,可是到底是由于什么原因导致这个错误的呢?

还是考虑环境变量,经检查发现一个隐晦的小错误。我的ORACLE_BASE设置成了如下形式:

ORACLE_BASE=/u01/app/

ORACLE_HOME=$ORACLE_BASE/oracle/product/11.2.0/xe

很明显,这里ORACLE_BASE最后面多了一个斜线,导致了这个错误,修改完成后,就完全正常了。

上面这整个流程,就是手动配置oracle用户的环境变量的整个过程。由于是第一次配置,所以犯了不少错误,但是这些错误让我更加理解整个过程。最后,设置了环境变量后别忘了在最后export进去。



Oracle用户的初始化问题的更多相关文章

  1. Oracle用户被锁原因及办法

    Oracle用户被锁原因及办法   在登陆时被告知test用户被锁 1.用dba角色的用户登陆,进行解锁,先设置具体时间格式,以便查看具体时间 SQL> alter session set nl ...

  2. oracle 用户与表空间关系

    oracle用户与表空间关系用户=商家表=商品表空间=仓库1. 1个商家能有很多商品,1个商品只能属于一个商家2. 1个商品可以放到仓库A,也可以放到仓库B,但不能同时放入A和B3. 仓库不属于任何商 ...

  3. Oracle 用户管理与权限控制

    Oracle 用户管理与权限控制 oracle数据库的权限系统分为系统权限与对象权限.系统权限( database system privilege )可以让用户执行特定的命令集.例如,create ...

  4. 【密码】Oracle用户密码系列

    [密码]Oracle用户密码系列 1.1  BLOG文档结构图 1.2  前言部分 1.2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识, ...

  5. oracle用户创建及权限设置及表空间

    建立表空间: create tablespace portx_data datafile 'D:\oracle_data\portx.dbf' size 50m autoextend on next ...

  6. 【oracle】解锁oracle用户,unlock

    解除oracle用户的锁定状态,例如oracle数据库建立测试实例时默认建立的scott用户,一开始是处于locked状态的,现在我们需要将其解锁,步骤如下: (1)在cmd中登录sqlplus,例如 ...

  7. oracle 用户的管理<二>

    oracle 用户的管理 创建用户 概述:在 oracle 中要创建一个新的用户使用 create user 语句,一般是具有 dba(数据库管理员)的权限才能使用. create user 用户名 ...

  8. Oracle用户、权限、角色管理(转)

    http://blog.csdn.net/junmail/article/details/4381287 Oracle 权限设置一.权限分类:系统权限:系统规定用户使用数据库的权限.(系统权限是对用户 ...

  9. oracle用户创建及权限设置

    权限: create session create table unlimited tablespace connect resource dba 例: #sqlplus /nolog SQL> ...

随机推荐

  1. x01.ExcelHelper: NPOI 操作

    Excel 操作,具有十分明显的针对性,故很难通用,但这并不妨碍参考后以解决自己的实际问题. 有一汇总表如下: 当然,只是示范,产品的代码应该唯一!现在要根据此汇总表产生各个客户的产品清单.由于客户较 ...

  2. SQl server 2012安装问题 error code 0x858C001b 解决方法

    英文版系统安装中文版sql server的缘故,改安装英文版即可.

  3. 谈谈关于PHP的代码安全相关的一些致命知识

    谈谈关于PHP的代码安全相关的一些致命知识 目标 本教程讲解如何防御最常见的安全威胁:SQL 注入.操纵 GET 和 POST 变量.缓冲区溢出攻击.跨站点脚本攻击.浏览器内的数据操纵和远程表单提交. ...

  4. 工厂设计模式 Factory

    Factory 主要用来实例化有共同接口的类,工厂模式可以动态决定应该实例化那一个类. 例如:汽车销售商场 该模式将创建对象的过程放在了一个静态方法中来实现.在实际编程中,如果需要大量的创建对象,该模 ...

  5. Android Project和app中两个build.gradle配置的区别

    Android 开发也挺长时间了,从开始就使用的AndroidStudio开发,但是说下来其实自己对AS(AndroidStudio简称)还真的是不了解不深入.好吧,其实我只知道AS是一个相当强大的工 ...

  6. MySQL学习笔记(三)

    --回顾 字段类型(列类型):数值型,时间日期型和字符串类型 数值型:整型和小数型(浮点型和定点型) 时间日期型:datetime,date,time,timestamp,year 字符串类型:定长, ...

  7. Spark源码阅读之存储体系--存储体系概述与shuffle服务

    一.概述 根据<深入理解Spark:核心思想与源码分析>一书,结合最新的spark源代码master分支进行源码阅读,对新版本的代码加上自己的一些理解,如有错误,希望指出. 1.块管理器B ...

  8. Sublime Text中安装插件来实现px与rem间的换算

    今天在群里无意中看到了群友分享的一篇关于移动端的文章.里面其他内容我倒不大感兴趣,反而是rem让我提起了兴趣. 首先来谈一下rem,rem是CSS3中新增加的一个单位值,它和em单位一样,都是一个相对 ...

  9. bzoj2038: [2009国家集训队]小Z的袜子(hose) [莫队]

    Description 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命……具体来说,小Z把这N只袜 ...

  10. (转)Linux系统安装时分区的选择

    场景:对于Linux系统的分区总是迷迷茫茫的,还是实践少,基础不牢. 以前初识Linux时,对Linux系统安装时分区的选择,一点都不了解,导致几次没法进行下一步安装,因此就静下心来,专门拿出时间研究 ...