码迷,mamicode.com
首页 > 其他好文 > 详细

enmo_day_02

时间:2015-07-31 12:05:09      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:

Secure CRT, putty, 等终端工具

DML :u, d, i, m 增,删,改,合并

DDL :

DCL :

DQL :

数据字典 :存放在数据文件中,SYSTEM表空间里,纪录数据的变化。

 

逻辑数据库结构

表空间tablespace :每个表空间由一个或多个数据库文件组成

段 segment:数据段,索引段,回退段,临时段

区 extent:磁盘空间分配的最小单位,存储于段中,由连续的数据快组成。

数据块block :数据库中最小的数据组织单位与管理单位,其大小有DB_BLOCK_SIZE参数决定,不同Oracle版本DB_BLOCK_SIZE的默认值不同

模式对象:表,聚簇,视图,索引序列生成器,同义词,哈西,程序单元,数据库链等

方案schema : 用户名,权限,数据结构等。

物理数据库结构

数据文件 :用户数据(用户表,DML语句可调整),数据字典数据

控制文件 :DB信息,日志序列号,归档信息,RMAN备份信息, 最后一次同步的SCN信息。大小一半不变。

eg : show parameter control

为保护控制文件使用多路复用的方法,同时使用多个控制文件,将其分开存放在不同的磁盘上。

日志文件 :按照时间顺序纪录数据的改变,大小不变,顺序写入,循环覆写,至少两组日志,日志成员冗余。

参数文件 : 纪录定制的数据参数,定义数据实例的属性,

eg : 

show parameter spfile;

alter system set processes=300 scope=spfile;

口令文件 :

归档日志文件 :重做日志历史,长期保存日志以便恢复,个数=当前日志数-1, 大小<=在线日志文件大小,命名唯一

database buffer cache数据高速缓存区 :缓存数据文件的读取

redo log buffer重做日志缓存区 :缓存重做日志的写入

shared pool : library cache, data dictionary cache

shared pool : library cache(存放执行计划), data dictionary cache

 

内存分配单位 :

SGA_TARGET :

eg :

show parameter sga_

MEMORY_TARGET :

eg :

show parameter memory_

 

程序全局区

大池 :

java池 :

进程结构:用户进程,服务器进程,后台进程

 

DBWn数据库写进程 (n表示多个)发生的条件:

发生检查点checkpoint

脏缓存达到限制

无自由缓存

超时发生

表空间离线,只读

表被删除或截断

热备份表空间开始动作

eg :

commit;

rollback;

conn hr/hr

create table test (id number)

insert into test values(1);

select * from test;

quit(正常退出(quit),自动执行commit操作,异常退出(rollback),自动执行rollback操作)

select * from test;(有结果)

打开宁一个终端,连接进hr

conn hr/hr

select * from test;(无结果)

insert into test values(2);

 

LGWR(日志写进程)写的条件:

commit时

达到三分之一满

日志的大小到1M

每个三秒

在DBWn进程写之前

eg :

 

 

 

note :

脏数据(内存中和数据文件中不一样的数据,内存中数据改动了)

空闲状态 :

干净数据(内存中和数据中一样的数据)

ping住(你改了,别人改不了了)

 

操作系统块 :

 

SYSTEM表空间是在数据库创建或安装时zidong创建的,用于存储系统的数据字典表,程序系统单元,过程函数,包和触发器等,也可用于存储用户数据表,索引对象。

 

eg :

desc dba_extends;

select * from dba_extends where rownum<2;

desc dba_segments;

select  * from dab_segments where 

 

create tablespace jilili datafile ‘u01/app/oracle/oradata/ENMOEDU/jilili01.dbf size 10m; :创建表空间

create table test (id number); : 创建段(表)默认表空间

drop table test purge;

create table test (id number) tablespace jilili; : 创建表并制定表空间

insert into test values (1);

desc dba_extends;

select * from dba_extends where segment_name=‘TEST’;

 

v$instance : v$开头表示oracle自己的动态性能视图。

select * from v$instance;

dba_users : 所有dba_,你权限下的all_, 你自己的user_开头表示, 权限不同

select * from dba_users;

 

 

select tablespace_name from dba_tablespaces;

SYSTEM, SYSAUX, UNDOTBS1, TEMP, USERS, EXAMPLE, 

 

自动内存管理的配置和使用方法 :

eg :

show parameter  pga_agg

show parameter size

show parameter sga

show parameter shared

show parameter pool

show parameter memory

show parameter cache

show parameter log_buffer

 

commit为什么不会写出脏数据?

commit只能触发LGWR的写进程,

 

批量提交(按需提交) VS 频繁提交?

Oracle提倡按需提交

undo表空间tablespace存放数据块前镜像。

 

insert

select

读写分开

SCN系统改变号 : Oracle内部的时钟

 

不提交会导致undo表空间过大

 

系统监控进程SMON :实例恢复(),释放临时表空间temp tablespace

进程监控进程PMON : 清楚失败进程(回滚事务,释放锁,释放其他资源,重启死掉的dispatchers, 动态注册监听器)

note : 监听器listener使用1521端口连接用户进程和服务器进程(通过网络访问服务器)

检查点进程CKPT(check point) : 给DBWn信号,更新数据文件头,跟新控制文件,协调DBWn和LGWR进程,查看DBWn进程写到的脏块,并记录到控制文件中(ctl)

归档进程ARCn : 可选的后台进程

 

完全检查点:把所有脏块全部写到数据文件中

增量检查点:根据链表把新的脏快写到磁盘

注 :链表纪录改变的块

 

一致性关闭数据库:脏块已经写到磁盘(数据文件)上,

手动执行check point : 

非一致性关闭数据库 :脏块没有写到磁盘(数据文件)上,只有shutdown abort.

 

shutdown normal : 正常关闭,关闭前退出所有会话

shutdown immediate :立即关闭,

shutdowntransactional :关闭前结束所有事物

shutdown abort :断电关闭,

 

eg :

su - oracle

sqlplus / as sysdba

alter system checkpoint; : 刷新所有脏快(把脏块写到磁盘)

 

open cursor

语法检查

语义检查

将语句转为hash值 (软解析)

解析

执行

获取,返回结果

close cursor

 

绑定变量 :为了让sql语句实现共享, 只能执行全表扫描(更适合OLTP,不适合OLAP)

eg :

select * from test where id := x;

 

 

注:

游标格式:

DECLARE 游标名称 CURSOR FOR SELECT 字段1,字段2,字段3,。。。FROM 表名 WHERE …

 

管理框架组建:

 

C/S :客户端服务器端

B/S : 浏览器服务器端

OEM :oracle enterprise manager 企业管理器

emctl start dbconsole : 启动OEM

 

 

通过一个sql语句的执行流程体现出整个体系结构图。

能画出体系结构图

 

emca

emca -config dbcontrol db -repos recreate

 

lsnrctl start

sqlplus / as sysdba

先启动监听器,后启动数据库

 

 

 

 

cd /u01/app/oracle/product/11.2.0/dbhome_1/sqlplus/admin

ls

vi glogin.sql

添加下面这行

SET SQLPROMPT “_USER’@‘_CONNECT_INDENTIFIER> ”

登陆浏览器:

用户名:sys

密码:oracle

 

 

create user user_name identified by pass_word :创建用户

alter user user_name identified by new_password :修改密码

 

工具:

sqlplus

SQL Developer

PL/SQL

 

desc v$instance;

select * from v$instance;

select INSTANCE_NAME, STATUS from v$instance;

set lines 200

column host_name format a10 : 规范特定列的长度

col host_name for a10 : 省略形式

select THREAD# from v$instance;

col thread# for 999

set pagesize 300

eg :

select * from v$instane

define _EDITOR=vim

ed

重新编辑上面的任务,保存

; :查看

/    :   执行

!ls : 不用退出sqlplus 执行操作系统命令

! : 跳到操作系统执行命令,不用退出sqlplus

exit : 回到sqlplus

 

note : ! 作用等于host

 

在 .bash_profile里写入 :

alias sqlplus =rwlrap sqlplus

alias rman=‘rlwrap rman’

可以实现滚动查找命令纪录

 

enmo_day_02

标签:

原文地址:http://www.cnblogs.com/jilili/p/4691481.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!