Oracle 命令和语句大全、实例启动关闭详解
ORACLE命令和语句
下面把大部分的指令做了记录和详细的注释。建议收藏、转发此篇文章,如果忘记可以翻出来查查。
用户与权限
创建用户
create user 用户名 identified by 密码;
给用户修改密码
alter user 用户名 identified by 新密码;
修改自己的密码
password 用户名;
删除用户
drop user 用户名 [cascade]可选参数 cascade
在删除用户时,注意: 如果要删除的用户,已经创建了表,那么就需要在删除的时候带一个参数 cascade; Cascade 有级联的作用
给用户赋权限
grant 权限/角色 to 用户名;
收回用户权限
revoke 权限/角色 from 用户名;
系统权限:是数据库管理相关的权限:create session(登录权限)、create table(创建表权限)、create index(创建索引权限)、create view(创建视图权限)、create sequence(创建序列权限)、create trriger(创建触发器权限)
connnect 角色:是授予用户的最基本的权利,能够连接到 oralce 数据库中,并在对其他用户的表有访问权限时,做 SELECT、UPDATE、INSERTT 等操作。Create session--建立会话;Alter session--修改会话;Create view--建立视图。Create sequence--建立序列等权限
resource 角色:具有创建表、序列、视图等权限。Create table--建表;Create trigger-- 建立促发器;Create procedure--建立过程;Create sequence—建立序列;Create type--建立类型等权限;
dba 角色:是授予系统管理员的,拥有该角色的用户就能成为系统管理员了,它拥有所有的系统权限。
表空间
创建表空间必须使用 system 用户创建
create tablespace hpu56(表空间名)
datafile 'E:\datebase\hpu6.DBF' //指定指向的数据文件路径
size 5m //初始化表空间大小为 5m
autoextend on next 2m //自动扩展,每次扩展 2m
maxsize unlimited; // unlimited最大扩展量没有限制,100M最大扩展到100M
创建用户指定默认表空间
create user 用户名 identified by 密码 default tablespace 表空间名;
修改用户默认表空间:
alter user 用户名 default tablespace 表空间名;
查看表空间:
select * from v$tablespace;
查看用户默认表空间:
select username,default_tablespace from dba_users where username='SCOTT';
注意:这里的用户名 SCOTT 必须是大写
表结构的操作
创建表:
create table 表的名称(字段名称 1 数据类型, 字段名称 2 数据类型);
create table 表的名称 as select 字段名称 1, 字段名称 2... from表的名称 ;
修改表
alter table 语句添加、修改或删除列的语法
添加列
alter table 表的名称 add(字段名称1 数据类型, 字段名称2 数据类型...);
alter table 表的名称 add 字段名称 数据类型;
修改列
alter table 表名 modify(字段名称1 数据类型, 字段名称2 数据类型...);
alter table 表名 modify字段名称 数据类型;
删除列
alter table 表名 drop(字段名称1 , 字段名称2,...);
alter table 表名 drop 字段名称;
修改表的名称
rename 表名 to 新表名;
修改列名
alter table 表名 rename column 旧列名 to 新列名;
查看表结构
desc 表名;
约束
约束分为: 非空(NOT NULL)约束、 唯一(UNIQUE)约束、主键(PRIMARY KEY)约束、外键(FOREIGN KEY)约束、条件(CHECK)约束,约束存在表user_constraints中。
非空(NOT NULL)
添加非空
create table 表名称 (字段名称1 数据类型,字段名称2 数据类型 not null);
alter table 表名 modify 字段名 not null;
删除非空
alter table 表名 modify 字段名 null;
唯一(UNIQUE)
添加修改唯一
create table 表名称 (字段名称1 数据类型,字段名称2 数据类型 unique);
alter table 表名 add constraint 约束名 unique (字段名称1,字段名称2);
删除唯一
alter table 表名 drop constratint 约束名称;
注意:oracle 中 unique 可以为 null,而且允许多行为 null
主键(PRIMARY KEY)
添加修改主键
create table 表名称 (字段名称1 数据类型,字段名称2 数据类型 primary key);
create table 表名称 (字段名称1 数据类型,字段名称2 数据类型 , constraint 约束名primary key (字段名称1,字段名称2));
alter table 表名 add constraint 约束名 primary key (字段名称1,字段名称2);
删除主键
alter table 表名 drop primary key cascade;
这是因为如果在两张表存在主从关系,那么在删除主要的主键约束时, 必需带上 cascade 选项
注意:每个表只能有且有一个主键约束。
特别说明 primary key 与 unique 的区别:
1、一张表可以有多个 unique(唯一)约束;
2、一张表只能有一个主键;
3、设置为主键的列不能有 null 值;
外键(FOREIGN KEY)
外键(FOREIGN KEY)约束:用来维护从表(Child Table)和主表(Parent Table)之间的引用完整性.能够维护数据库的数据一致性,数据的完整性。防止错误的垃圾数据入库;
用于定义主表和从表之间的关系,外键约束要定义在从表上,主表则必需具有主键约束或是 unique 约束,当定义外键约束后,要求外键列数据必需在主表的主键列存在或是为 null
添加修改主键
create table 表名称 (字段名称1 数据类型,字段名称2 数据类型 references 主表名称(字段名) );
create table 表名称 (字段名称1 数据类型,字段名称2 数据类型 , constraint 约束名 foreign key (字段名称) references主表名称(字段名)));
alter table 表名 add constraint 约束名 foreign key(字段名称) references 主表名称(字段名);
删除主键
alter table 表名 drop constratint 约束名称;
特别说明:froeign key 外键的细节
1、外键指向主键列;
2、外键可以指向 unique 列;
3、建表时先建主表,再建从表;删除表先删从表,再删主表。
4、外键列属性值要与主键或 unique 列属性值的类型保持一致
5、外键列的值,必需在主键列中存在。但外键列的值允许为 null
条件(CHECK)
添加修改条件
create table 表名称 (字段名称1 数据类型,字段名称2 数据类型 check (字段名称2 in (值1,值2...)));
alter table 表名 add constraint 约束名 check (字段名称 in (值1,值2...));
删除条件
alter table 表名 drop constratint 约束名称;
约束命名规则:
非空约束: NN_表名_列名
唯一约束: UK_表名_列名
主键约束: PK_表名
外键约束: FK_表名_列名
条件约束: CK_表名_列名
显示表约束信息
select * from user_constraints where table_name = '表名';
数据操作
添加数据
insert into 表名[(列名 [,列名 2...])] values(值 [,值 2...]);
插入全部数据
insert into 表名 values(值 [,值 2...]);
从表中导入数据
insert into 表名 (select 值1,值2,值3...from 表名2 );
修改数据
update 表名 set 列名=表达式 [,列名 2=表达式 2,...][where 条件];
删除数据
delete from 表名 [where 条件表达式];
删除的几种方法比较:
delete from 表名;
删除所有记录,表结构还在,写日志,可以恢复的,速度慢
drop table 表名;
删除表的结构和数据
truncate table 表名;
删除表中的所有记录,表结构还在,不写日志,无法找回删除的记录,速度快。
基本查询数据
基本语法:
select [是否剔除重复数据] *|{字段名(列名),字段名 2(列名 2),字段名 3(列名 3)..} from 表名 [where {条件}];
注意事项:
1、select 指定查询哪些列的数据;
2、column 指定列名;
3、*代表查询所有列;
4、from 指定查询哪张表;
5、distinct 可选,指显示结果时,是否剔除重复数据;
6、where 条件。
使用列的别名
select ename as "姓名",sal*13+nvl(comm,0)*13 as "年收入" from emp;
特别注意:
oracle 在使用别名时,可以用双引号或不使用或使用 as 来表明别名。但不能使用单引号。
如何处理 null 值
nvl 函数:oracle 提供的函数,是用于处理 null 值使用的。
SQL>select ename,sal*13+nvl(comm,0)*13 from emp;
nvl(值 1,值 2) 解释:nvl 值 1 为 null 时则取值 2,值 1 不为 null 时则取值 1 原值。
如何连接字符串(||)
在查询的时候,希望把多列内容做为一列内容返回可以使用||连接符。
SQL>select ename ||'年收入'||(sal*13+nvl(comm,0)*13) "雇员的年收入" from emp;
取范围内的值(between)
SQL>select * from emp where sal between 2000 and 2500;
between 是指定区间内取值,如:between 2000 and 2500,取 2000 至 2500 内的值,同时包含
2000 和 2500
如何使用 like 操作符
%:表示任意 0 到多个字符
_:表示任意单个字符
1)如何显示首字符为 S 的员工姓名和工资
SQL>select ename,sal from emp where ename like 'S%';
2)如何显示第三个字符为大写 O 的所有员工的姓名和工资
SQL>select ename,sal from emp where ename link 'O%';
在 where 条件中使用 in
SQL>select * from emp where empno in(123,345,800);
注意:in 只能放1000个值
使用 is null 的操作符
在查询语句中不能使用=或者!=null判断是否为空
SQL>select * from emp where mgr is null;
SQL>select * from emp where mgr is not null;
使用逻辑操作符号
查询工资高于 500 或是岗位为 manager 的雇员,同时还要满足他们的姓名首写字母为大写的 J
SQL>select * from emp where (sal>500 or job='MANAGER') and (ename like 'J%');
使用 order by 子句
如何按照工资的从低到高的顺序显示雇员的信息
SQL>select * from emp order by sal asc;
注意:asc 写或不写都是升序排序即从小到大排序,desc 则是降序排序从大到小排序。
使用列的别名排序
SQL>select ename,sal*12 "年薪" from emp order by "年薪" asc;
别名需要使用“”号圈中。
Oracle分组查询
在实际应用中经常需要执行复杂的数据统计,经常需要显示多张表的数据;要用到分组函数 max,min,avg,sum,count
Max(),min()最大最小
如何显示所有员工中最高工资和最低工资
SQL>select max(sal) "最高工资",min(sal) "最低工资" from emp;
请查询最高年工资
SQL>select max(sal*13+nvl(comm,0)*13) "最高年工资",min(sal*13+nvl(comm,0)*13) "最低年工资" from
emp;
Avg()求平均
显示所有员工的平均工资和工资总和
SQL>select avg(sal) "平均工资",sum(sal) "工资总和" from emp;
特别注意:
avg(sal)不会把 sal 为 null 的行进行统计,因此我们要注意,如果为空值也考虑,则可以
SQL>selec sum(sal)/count(*) from emp;
count(*)求总数
计算共有多少员工
SQL>select count(*) "共有员工" from emp;
group by 和 having 子句
group by:用于对查询的结果分组统计;
having 子句:用于限制(过滤)分组显示结果
1)如何显示每个部门的平均工资和最高工资
SQL>select avg(sal) "平均工资",max(sal) "最高工资",deptno "部门编号" from emp group by deptno;
2)显示每个部门的每种岗位的平均工资和最低工资
SQL>select avg(sal) "平均工资",min(sal) "最低工资",job "职位",deptno "部门编号" from emp group by deptno,job order by deptno;
对数据分组的总结:
1、分组函数(avg...)只能出现在选择列表、having、order by 子句中;
2、如果在 select 语句中同时包含有 group by/having/order by 那么他们的顺序是 group by/having/order
by;
3、在选择列中如果有列、表达式和分组函数,那么这些列和表达式必需有一个出现在 group by 子句中,否则会出错。
Oralce函数
Ascii()
返回与指定的字符对应的十进制数;
SQL>select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;
chr()
给出整数,返回对应的字符;
SQL>select chr(54740) zhao,chr(65) chr65 from dual;
concat()
连接两个字符串,与||作用相同;
SQL>select concat('hello','world') from dual;
initcap()
返回字符串并将字符串的第一个字母变成大写;
SQL>select initcap('smith') upp from dual;
instr(C1,C2,I,J)
在一个字符串中搜索指定的字符,返回发现指定的字符的位置;
C1 被搜索的字符串;
C2 希望搜索的字符串;
I 搜索的开始位置,默认为 1;
J 第 j 次出现的位置,默认为 1;
SQL>select instr('oracle training','ra',1,2) instring from dual;
length()
返回字符串的长度;
SQL>select ename, length(ename) , job , length(job), sal, length(to_char(sal)) from emp where ename='SMITH';
lower()
返回字符串,并将所有的字符小写;
SQL>select lower('AaBbCcDd') "lower-AaBbCcDd" from dual;
upper()
返回字符串,并将所有的字符大写;
SQL>select upper('AaBbCcDd') "upper-AaBbCcDd" from dual;
rpad 和 lpad(粘贴字符)
rpad 在列的右边粘贴字符 rpad('显示内容'或字段,显示长度,'填充占位符')
lpad 在列的左边粘贴字符 lpad('显示内容'或字段,显示长度,'填充占位符')
SQL>select lpad(rpad('htf',10,'*'),17,'*') from dual;
ltrim 和 rtrim
ltrim 删除左边出现的字符串 ltrim('原内容'或字段,'要删除的字符串')
rtrim 删除右边出现的字符串 rtrim('原内容'或字段,'要删除的字符串')
SQL>select rtrim('**han teng fei**','*') from dual;
substr(string,start,count)
取子字符串,从 start 开始,取 count 个
SQL>select substr('13088888888',3,8) from dual;
replace('string','s1','s2')
string 希望被替换的字符或变量
s1 被替换的字符串
s2 要替换的字符串
SQL>select replace('he love you','he','i') from dual;
trim('s' from 'string')
如果不指定参数,默认为空格符。
SQL>select trim(0 from 0009872348900) "trim example" from dual;
## 数学函数
ceil(向上取整)
返回大于或等于给出数字的最小整数;
SQL>select ceil(3.14159265) from dual;
floor(向下取整)
对给定的数字取整数;
SQL>select floor(2345.67) from dual;
trunc(精度截取)
按照指定的精度截取一个数;
SQL>select trunc(124.1666,-2),trunc(124.16666,2) from dual;
round 和 trunk
按照指定的精度进行舍入;
round 函数为四舍五入
trunc(直接截取)
SQL>select round(55.5),round(-55.4),trunc(55.5),trunc(-55.5) from dual;
abs
返回指定值的绝对值;
SQL>select abs(100),abs(-100) from dual;
acos
给出反余弦的值;
SQL>select acos(-1) from dual;
asin
给出反正弦的值;
SQL>select asin(0.5) from dual;
atan
返回一个数字的反正切值;
SQL>select atan(1) from dual;
cos
返回一个给定数字的余弦;
SQL>select cos(-3.14159265) from dual;
mod(n1,n2)
返回一个 n1 除以 n2 的余数;(取模函数)
SQL>select mod(10,3),mod(3,3),mod(2,3) from dual;
日期函数
介绍 :日期函数用于处理 date 类型的数据。
默认情况下日期格式是 dd-mon-yy 即 12-7 月-78
add_months(掌握)
add_months(日期值,增加(减少)值)增加或减去月份;
SQL>select to_char(add_months(to_date('199912','yyyymm'),2),'yyyymm') from dual;
last_day
返回日期当月的最后一天;
SQL>select to_char(last_day(sysdate),'yyyy-mm-dd') from dual;
months_between(date2,date1)
给出 date2-date1 的月份,共有多少个月;
SQL>select months_between('19-12 月-1999','19-3 月-1999') mon_between from dual;
next_day(date,'day')
给出日期 date 和星期 X(day)之后计算下一个星期的日期;
SQL>select next_day('1-3 月-2017','星期五') next_day from dual;
Sysdate
用来得到系统的当前日期;
SQL>select to_char(sysdate,'day') from dual;
## 转换类型函数
to_char(date,'format')
日期类型转换成字符串格式(主要用于将日期以习惯的格式输出显示)
SQL>select to_char(sysdate,'yyyy/mm/dd hh24:mi:ss') from dual;
to_char()
特别说明: 日期格式:
yy:两位数字的年份 2004--04
yyyy:四位数字的年份 2004 年
mm:两位数字的月份 8 月--08
dd:两位数字的天数 30 号--30
hh24:二十四小时制 8 点--20
hh12:十二小时制 8 点--08 mi,ss--显示分钟\秒
day 显示星期几
month 显示几月
year 显示年
数字格式:
9:显示数字,并忽略前面 0
0:显示数字,如位数不足,则用 0 补齐
.:在指定位置显示小数点
,:在指定位置显示逗号
$:在数字前加美元符号
L:在数字前加本地货币符号
C:在数字前加国际货币符号
G:在指定位置显示组分隔符 D:在指定位置显示小数点符号(.)
说明:,逗号.和小数点可以合在一起使用,G 分隔符和 D 小数点符可以合在一起使用,但,.不能和 GD
综合使用,否则报错。
to_date(string,'format')
将字符串转换成日期(主要用于将日期按习惯的格式输入到 oracle 数据库中)
to_number
将给出的数字类型的字符转换为数字;
系统函数
decode 函数类似于 java 的 switch case 分支语句
decode (value, if1, then1, if2,then2, if3,then3, . . . else )
DECODE(VALUE,‘0’,‘1’,‘2’)
若value为0,则为1,否则为2
表之间的连接
自连接
指在同一张表的连接查询(把一张表看作两张表)
显示员工的上级领导的姓名
SQL>select e2.ename from emp e1,emp e2 where e1.mgr=e2.empno;
内连接(inner join - on)
内连接基本语法:
select 列名 1,.. from 表 1 inner join 表 2 on 条件;
说明:内连接只有两张表同时满足条件才会被查询到。
显示员工的信息和部门名称
SQL>select e.*,d.dname from emp e,dept d where e.deptno=d.deptno;
等价于
SQL>select e.*,d.dname from emp e inner join dept d on e.deptno=d.deptno;
左外连接 (left join - on)
如果左侧的表完全显示我们就说是左外连接
基本语法:
select 列名 1,列名 2,.. from 表 1 left join 表 2 on 条件;
select 列名 1,列名 2,.. from 表 1,表 2 where 条件 1=条件 2(+);
右外连接 (right join - on)
如果右侧的表完全显示我们就说是右外连接
基本语法:
select 列名 1,列名 2,.. from 表 1 right join 表 2 on 条件;
select 列名 1,列名 2,.. from 表 1,表 2 where 条件 1(+)=条件 2;
完全外连 (full outer join - on)
完全显示两个表,没有匹配的记录置为空
基本语法:
select 列名 1,列 2,.. from 表 1 full outer join 表 2 on 条件;
分页查询
select t2.* from ( select t1.*, rownum rn from (select * from 表名) t1
where rownum<=大范围(取到多少条数据)) t2 where rn>=小范围(从第几条数据开始取);
特别说明:
oracle 分页查询是通过三层筛选法进行查询的。每一次都可以带 where 条件来对要查询的信息进行筛选。
第一层:构建我们所要查询字段信息并排序;
第二层:构建 rownum 别名 rn
第三层:加 where 条件,rn>=M and rn <=N
oracle视图
创建视图基本语法:
create view 视图名 as select 语句 [with read only]
特别说明:with read only 如果带上的话,只能查询,不能改写。
创建或修改视图基本语法:
create or replace view 视图名 as select 语句 [with read only]
特别说明:with read only 如果带上的话,只能查询,不能改写。
删除视图基本语法:
drop view 视图名;
Oracle数据库实例启动关闭过程
Oracle数据库实例的启动,严格来说应该是实例的启动,数据库仅仅是在实例启动后进行装载。Oracle数据启动的过程被划分为
几个不同的步骤,在不同的启动过程中,我们可以对其实现不同的操作,系统修复等等工作,因此了解Oracle数据启动、关闭是非常
有必要的。下面详细了Oracle Database 10g 数据库启动及关闭的过程。
一、数据库实例的启动
二、数据库实例的关闭
关闭命令:shutdowm abort | immediate | transactional | normal (shutdown不带参数将缺省为normal)
关闭选项:
normal --->不准许新的连接,等待当前的session 结束,等待当前的事务结束,强制检查点并关闭文件
transactional --->不准许新的连接,不等待当前的session结束,等待当前的事务结束,强制检查点并关闭文件。
immediate --->不准许新的连接,不等待当前的session结束,不等待当前的事务结束,强制检查点并关闭文件。
abort --->不准许新的连接,不等待当前的session结束,不等待当前的事务结束,不作强制检查点。
三、几类诊断文件
包含有重要意义时间的具体信息,用于解决问题,用于日常更好的管理数据库
a.alterSID.log 告警文件
记录了数据库启动、关闭时间和一些重要操作及错误警告信息,包含错误号ora-,由dba管理
位置由background_dump_dest
维护alertSID.log,定期转移,系统会自动产生新的alert_sid.log
b.后台进程跟踪文件:
记录了后台进程的一些重要信息和警告、错误等
位置:$ORACLE_BASE/admin/vvorcl/bdump/vvorcl_lgwr_15135.trc
c.用户跟踪文件:
由用户进程产生也能由服务器进程产生,跟踪用户的SQL语句的统计信息,也包括错误信息
文件位置由user_dump_dest
用户跟踪:
会话级:
alter session set sql_trace=true;
实例级:
alter system set set sql_trace=true;
跟踪文件的大小由max_dump_file_size参数决定。跟踪时最好要限制他的大小
四、动态性能视图
记录当前数据库的活动,并且不停的更新,故不能保证读取数据的一致性
监控和调整数据库
所有者sys
以v开头
DICT和DICT_COLUMNS视图包含了动态性能视图描述及其列的描述
vFIXED_TALBE包含了所有视图的名字及相关信息
五、演示
[root@robinson ~]# su - oracle
--查看未启动实例前的进程情况
[oracle@robinson ~]ps -aef |grep oracle
root 3332 3300 0 12:20 pts/1 00:00:00 su - oracle
oracle 3333 3332 0 12:20 pts/1 00:00:00 -bash
oracle 3365 3333 0 12:20 pts/1 00:00:00 ps -aef
oracle 3366 3333 0 12:20 pts/1 00:00:00 grep oracle
--使用ipcs查看当前进程间通讯所用到的共享资源,内存段及信号量,
--可以看出当前无任何通信设备及共享资源
[oracle@robinson ~] ipcs -a
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
------ Semaphore Arrays --------
key semid owner perms nsems
------ Message Queues --------
key msqid owner perms used-bytes messages
--登陆到sqlplus
[oracle@robinson ~]sqlplus / as sysdba
SQL*Plus: Release 10.2.0.1.0 - Production on Thu Apr 29 13:07:29 2010
Copyright (c) 1982, 2005, Oracle. All rights reserved.
Connected to an idle instance.
--再次查看进程情况,多出了进程
SQL> !ps -aef | grep oracle
root 3332 3300 0 12:20 pts/1 00:00:00 su - oracle
oracle 3333 3332 0 12:20 pts/1 00:00:00 -bash
oracle 3972 3333 0 13:07 pts/1 00:00:00 sqlplus as sysdba
oracle 3973 3972 0 13:07 ? 00:00:00 oracleorcl (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))
oracle 3974 3972 0 13:07 pts/1 00:00:00 /bin/bash -c ps -aef | grep oracle
oracle 3975 3974 0 13:07 pts/1 00:00:00 ps -aef
--再次查看进程间通讯资源,同样是没有任何分配
SQL> !ipcs -a
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
------ Semaphore Arrays --------
key semid owner perms nsems
------ Message Queues --------
key msqid owner perms used-bytes messages
--启动到nomount
SQL> startup nomount
ORACLE instance started.
Total System Global Area 398458880 bytes
Fixed Size 1219640 bytes
Variable Size 117441480 bytes
Database Buffers 276824064 bytes
Redo Buffers 2973696 bytes
--可以看到多出了一些后台进程,即为Oracle的后台进程。从开始。
SQL> !ps -aef | grep oracle
root 3332 3300 0 12:20 pts/1 00:00:00 su - oracle
oracle 3333 3332 0 12:20 pts/1 00:00:00 -bash
oracle 3972 3333 0 13:07 pts/1 00:00:00 sqlplus as sysdba
oracle 3981 1 0 13:09 ? 00:00:00 ora_pmon_orcl
oracle 3983 1 0 13:09 ? 00:00:00 ora_psp0_orcl
oracle 3985 1 0 13:09 ? 00:00:00 ora_mman_orcl
oracle 3987 1 0 13:09 ? 00:00:00 ora_dbw0_orcl
oracle 3989 1 0 13:09 ? 00:00:00 ora_lgwr_orcl
oracle 3991 1 0 13:09 ? 00:00:00 ora_ckpt_orcl
oracle 3993 1 0 13:09 ? 00:00:00 ora_smon_orcl
oracle 3995 1 0 13:09 ? 00:00:00 ora_reco_orcl
oracle 3997 1 0 13:09 ? 00:00:00 ora_cjq0_orcl
oracle 3999 1 0 13:09 ? 00:00:00 ora_mmon_orcl
oracle 4001 1 0 13:09 ? 00:00:00 ora_mmnl_orcl
oracle 4003 1 0 13:09 ? 00:00:00 ora_d000_orcl
oracle 4005 1 0 13:09 ? 00:00:00 ora_s000_orcl
oracle 4006 3972 0 13:09 ? 00:00:00 oracleorcl (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))
oracle 4009 3972 0 13:10 pts/1 00:00:00 /bin/bash -c ps -aef | grep oracle
oracle 4010 4009 0 13:10 pts/1 00:00:00 ps -aef
--可以看到已经分配了SGA
SQL> !ipcs -a
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
0x99eb282c 65537 oracle 640 402653184 14
------ Semaphore Arrays --------
key semid owner perms nsems
0x6df43ca0 98304 oracle 640 127
0x6df43ca1 131073 oracle 640 127
0x6df43ca2 163842 oracle 640 127
------ Message Queues --------
key msqid owner perms used-bytes messages
--查看控制文件,没有任何数据,因为此阶段控制文件并没有打开
SQL> select * from vcontrolfile;
no rows selected
--查看数据文件和日志文件,提示database not mounted
SQL> select * from vdatafile;
select * from vdatafile
*
ERROR at line 1:
ORA-01507: database not mounted
SQL> select * from vlogfile;
select * from vlogfile
*
ERROR at line 1:
ORA-01507: database not mounted
--切换到mount阶段
SQL> alter database mount;
Database altered.
--可以查看控制文件的相关信息
SQL> select * from vcontrolfile;
STATUS NAME IS_ BLOCK_SIZE FILE_SIZE_BLKS
------- -------------------------------------------------- --- ---------- --------------
/u01/app/oracle/oradata/orcl/control01.ctl NO 16384 430
/u01/app/oracle/oradata/orcl/control02.ctl NO 16384 430
/u01/app/oracle/oradata/orcl/control03.ctl NO 16384 430
--可以查看数据文件的相关信息
SQL> select FILE#,STATUS,ENABLED,CHECKPOINT_CHANGE#,CHECKPOINT_TIME,ONLINE_TIME,NAME from vdatafile;
FILE# STATUS ENABLED CHECKPOINT_CHANGE# CHECKPOIN ONLINE_TI NAME
---------- ------- ---------- ------------------ --------- --------- --------------------------------------------------
1 SYSTEM READ WRITE 2027235 28-APR-10 06-APR-10 /u01/app/oracle/oradata/orcl/system01.dbf
2 ONLINE READ WRITE 2027235 28-APR-10 06-APR-10 /u01/app/oracle/oradata/orcl/undotbs01.dbf
3 ONLINE READ WRITE 2027235 28-APR-10 06-APR-10 /u01/app/oracle/oradata/orcl/sysaux01.dbf
4 ONLINE READ WRITE 2027235 28-APR-10 06-APR-10 /u01/app/oracle/oradata/orcl/users01.dbf
5 ONLINE READ WRITE 2027235 28-APR-10 /u01/app/oracle/oradata/orcl/example01.dbf
6 ONLINE READ WRITE 2027235 28-APR-10 /u01/app/oracle/oradata/orcl/Test.dbf
7 ONLINE READ WRITE 2027235 28-APR-10 /u01/app/oracle/oradata/orcl/ORCL/datafile/o1_mf_s
_5vrl1t7h_.dbf
--可以查看日志文件的相关信息
SQL> select * from vlogfile;
GROUP# STATUS TYPE MEMBER IS_
---------- ------- ------- ------------------------------------------------------------ ---
3 ONLINE /u01/app/oracle/oradata/orcl/redo03.log NO
2 ONLINE /u01/app/oracle/oradata/orcl/redo02.log NO
1 ONLINE /u01/app/oracle/oradata/orcl/redo01.log NO
--数据不可访问,因为在此阶段,数据文件,日志文件并没有打开
SQL> select * from scott.emp;
select * from scott.emp
*
ERROR at line 1:
ORA-01219: database not open: queries allowed on fixed tables/views only
--切换到open 阶段
SQL> alter database open;
Database altered.
--再次查看进程信息,多出了之后的相关进程
SQL> !ps -aef | grep oracle
oracle 3981 1 0 13:09 ? 00:00:00 ora_pmon_orcl
oracle 3983 1 0 13:09 ? 00:00:00 ora_psp0_orcl
oracle 3985 1 0 13:09 ? 00:00:00 ora_mman_orcl
oracle 3987 1 0 13:09 ? 00:00:00 ora_dbw0_orcl
oracle 3989 1 0 13:09 ? 00:00:00 ora_lgwr_orcl
oracle 3991 1 0 13:09 ? 00:00:00 ora_ckpt_orcl
oracle 3993 1 0 13:09 ? 00:00:00 ora_smon_orcl
oracle 3995 1 0 13:09 ? 00:00:00 ora_reco_orcl
oracle 3997 1 0 13:09 ? 00:00:00 ora_cjq0_orcl
oracle 3999 1 0 13:09 ? 00:00:00 ora_mmon_orcl
oracle 4001 1 0 13:09 ? 00:00:00 ora_mmnl_orcl
oracle 4003 1 0 13:09 ? 00:00:00 ora_d000_orcl
oracle 4005 1 0 13:09 ? 00:00:00 ora_s000_orcl
root 4068 4036 0 13:29 pts/1 00:00:00 su - oracle
oracle 4069 4068 0 13:29 pts/1 00:00:00 -bash
oracle 4101 4069 0 13:29 pts/1 00:00:00 sqlplus
oracle 4102 4101 0 13:29 ? 00:00:01 oracleorcl (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))
oracle 4137 1 0 13:54 ? 00:00:00 ora_qmnc_orcl
oracle 4139 1 0 13:54 ? 00:00:01 ora_j000_orcl
oracle 4141 1 0 13:54 ? 00:00:00 ora_j001_orcl
oracle 4143 1 0 13:54 ? 00:00:00 ora_j002_orcl
oracle 4145 1 0 13:54 ? 00:00:00 ora_j003_orcl
oracle 4147 1 0 13:54 ? 00:00:00 ora_j004_orcl
oracle 4149 1 0 13:54 ? 00:00:00 ora_j005_orcl
oracle 4159 1 0 13:54 ? 00:00:00 ora_q001_orcl
oracle 4167 1 0 13:56 ? 00:00:00 ora_q002_orcl
oracle 4169 1 0 13:57 ? 00:00:00 ora_q003_orcl
oracle 4172 4101 0 13:58 pts/1 00:00:00 /bin/bash -c ps -aef | grep oracle
oracle 4173 4172 0 13:58 pts/1 00:00:00 ps -aef
--数据已可正常访问
SQL> select * from scott.emp where ename = 'SCOTT';
EMPNO ENAME JOB MGR HIREDATE SAL COMM
---------- ---------- --------- ---------- --------- ---------- ----------
DEPTNO
----------
7788 SCOTT ANALYST 7566 19-APR-87 3000
--查看告警日志文件路径
SQL> show parameter background_dump_dest
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
background_dump_dest string /u01/app/oracle/admin/orcl/bdu
mp
--查看动态性能视图
SQL> select sql_text,executions from vsql where cpu_time >2000000;
SQL_TEXT
--------------------------------------------------------------------------------
EXECUTIONS
----------
select s.synonym_name object_name, o.object_type from all_synonyms s, sys.a
ll_objects o where s.owner in ('PUBLIC', :schema) and o.owner = s.table_owner an
d o.object_name = s.table_name and o.object_type in ('TABLE', 'VIEW', 'PACKAGE',
'TYPE', 'PROCEDURE', 'FUNCTION', 'SEQUENCE')
2
SQL> select username,status,server,state from vsession where program = 'plsqldev.exe';
USERNAME STATUS SERVER STATE
------------------------------ -------- --------- -------------------
SYS INACTIVE DEDICATED WAITING
SYS INACTIVE DEDICATED WAITING
SQL> select sid,ctime from vlock where sid = 275;
SID CTIME
---------- ----------
275 9607
275 9270
275 9243