enmo_day_02
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的更多相关文章
随机推荐
- 从表中删除重复记录的sql
--有一个表,假设是这样的 CREATE TABLE Test ( field1 ) primary key, field2 )); --假设field1上有索引. 要删除表中所有field1重复的记 ...
- s3c2440 移值新内核 linux-4.1.36
arm-linuxgcc version 4.3.2 经过试验,最高可以编译到 linux-4.1.36 ,在高的版本会有错误 ,可能是 GCC 编译器版本较低造成. 解压比较麻烦还要装一个 xz x ...
- javadoc 生成文档注释
我们可以通过 javadoc 命令从文档注释中提取内容,生成程序的 API 帮助文档. javadoc -d doc demo.java 文档注释:/******/ @author 标明开发该类模块的 ...
- IOS开发之异步加载网络图片并缓存本地实现瀑布流(二)
/* * @brief 图片加载通用函数 * @parma imageName 图片名 */ - (void)imageStartLoading:(NSString *)imageName{ NSUR ...
- 一个java的DES加密解密类转换成C#
一个java的des加密解密代码如下: //package com.visionsky.util; import java.security.*; //import java.util.regex.P ...
- HQL基础Query简单查询结果for输出和Iterator输出
HQL第一次课: hibernate Query Language:hibernate 查询语言 语法: query: String hql="from dept"; Query ...
- package
1.设计package原因 理解基目录的概念,思考jre加载class的顺序,如果没有package会怎么样?有了之后又是怎么样..? 主要:确保类名的唯一性. 次要:方便组织代码 2.怎样访问\导入 ...
- hdu 5542 The Battle of Chibi(2015CCPC - C题)
题目链接:hdu 5542 首届CCPC的C题,比赛时一起搞了好久,最后是队友A出的,当时有试过用树状数组来优化 dp,然后今天下午也用树状数组搞了一下午,结果还是踩了和当时一样的坑:我总是把用来记录 ...
- JQuery基础核心
一.代码风格 在jQuery程序中,不管是页面元素的选择.内置的功能函数,都是美元符号“$”来起始的. 而这个“$”就是jQuery当中最重要且独有的对象:jQuery对象,所以我们在页面元素选择或执 ...
- iOS开发 沙盒路径和使用
1.模拟器沙盒目录文件都在个人用户名文件夹下的一个隐藏文件夹里,中文叫资源库,他的目录其实是Library.因为应用是在沙箱(sandbox)中的,在文件读写权限上受到限制,只能在几个目录下读写文件: ...