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的更多相关文章
随机推荐
- jsp通过jQuery返回json数据到页面
1.首先要导入json的包,自己去网站找,总共6个jar包! 2. 在servlet里的写法(仅共参考) JSONObject json = new JSONObject(); String a = ...
- StringBuilder和Append的一个程序及一个基础概念
废话少说直接来说:比如在串口数据操作中,我们只想显示串口接收的字符串,好吧你用string[]吧,有多少个字符串(顺便说下二进制在C#中是以字符串形式出现的)就要分配多少个储存空间,自己试下,要你你干 ...
- 初试“七牛云”--零基础运用七牛云配合UEditor实现图片的上传和浏览(.NET篇)
(注册和建立存储空间就不介绍了,网上一把一把的资料,自己试着点点也能明白) 作为一个成熟的菜鸟,如果遇到一个新问题,第一步当然是先百度一下... 看了N个关于七牛云的使用的帖子,表示还是蒙圈的,看懂了 ...
- Mayor's posters(线段树+离散化POJ2528)
Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 51175 Accepted: 14820 Des ...
- C++ Programming language读书笔记
C语言,结构化程序设计.自顶向下.逐步求精及模块化的程序设计方法;使用三种基本控制结构构造程序,任何程序都可由顺序.选择.循环三种基本控制结构构造. 模块结构:"独立功能,单出.入口&quo ...
- JAVA基础知识之NIO——Buffer.Channel,Charset,Channel文件锁
NIO机制 NIO即NEW IO的意思,是JDK1.4提供的针对旧IO体系进行改进之后的IO,新增了许多新类,放在java.nio包下,并对java.io下许多类进行了修改,以便使用与nio. 在ja ...
- dojox.grid.DataGrid
创建表格 <table data-dojo-type="dojox.grid.DataGrid" data-dojo-id="grid" style=&q ...
- Beaglebone Black–I2C 接 BMP280 获取当前温度
我有两个含温度传感的模块,一个是AOSONG 奥松电子的 AM2320 温度湿度,另一个是九轴里面的 Bosch BMP280.由于 AM2320 用 I2C MODBUS,直接用 I2C Tools ...
- 后勤数据源增量队列Delta Queue(RSA7)中的增量更新区Delta Update、增量重复区Delta Repetition
声明:原创作品,转载时请注明文章来自SAP师太技术博客:( 博/客/园www.cnblogs.com)www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- Reverse a singly linked list
Reverse a singly linked list. /** * Definition for singly-linked list. * struct ListNode { * int val ...