oracle从入门到精通(PDF格式)-第16部分
按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!
4。手动分配区:
alter table hr。employees allocate extent(size 500k datafile 'filepath');
5。非分区表的重组
alter table owner。table move tablespace space_name;
当表被重组后,它的结构被重组,但内容没有影响;
约束条件不变,但与其对应的索引不存在了,所以重组之后的索引必须重建;
可以被用于移动表到新的表空间或者重组区;
6。删除列:
alter table owner。table_name drop
column col_name cascade constraints checkpoint 1000;
checkpoint 1000 每一千行 执行一次检查点
检查点:完成同步,将写入日志的改变对应的数据写入数据文件中;
从每行中删除掉列占据的长度和数据,释放在数据块中占用的空间。
删除大表中的一列将花费比较长的时间。
7。重命名表中的一列:
alter table owner。table_name
第 68 页,共 106 页
…………………………………………………………Page 69……………………………………………………………
资源来自网络,仅供学习! Oracle 从入门到精通
rename column old_name to new_name;
8。标记列不再使用:
alter table owner。table_name
set unused column col_name cascade constraints;
9。删除不使用的列:
alter table owner。table_name
drop unused columns checkpoint 1000;
10。继续列的删除操作:
alter table owner。table_name
drop columns continue checkpoint 1000;
11。得到表的信息:
DBA_TABLES DBA_OBJECTS
22、管理索引(index)
关键字+ROWID,排序!!!
1。索引的分类:
逻辑上:
Single column 单行索引
Concatenated 多行索引
Unique 唯一索引
NonUnique 非唯一索引
Function…based 函数索引
Domain 域索引
物理上:
Partitioned 分区索引
NonPartitioned 非分区索引
B…tree:
Normal 正常型 B 树
Rever Key 反转型 B 树
Bitmap 位图索引
2。索引结构:
B…tree:
适合与大量的增、删、改(OLTP);
第 69 页,共 106 页
…………………………………………………………Page 70……………………………………………………………
资源来自网络,仅供学习! Oracle 从入门到精通
不能用包含 OR 操作符的查询;
适合高基数的列(唯一值多)
典型的树状结构;
每个结点都是数据块;
大多都是物理上一层、两层或三层不定,逻辑上三层;
叶子块数据是排序的,从左向右递增;
在分支块和根块中放的是索引的范围;
Bitmap:
适合与决策支持系统;
做 UPDATE 代价非常高;
非常适合 OR操作符的查询;
基数比较少的时候才能建位图索引;
树型结构:
索引头
开始 ROWID,结束 ROWID(先列出索引的最大范围)
BITMAP
每一个 BIT对应着一个 ROWID,它的值是 1 还是0,如果是 1,表示着 BIT对应
的 ROWID 有值;
3。存储参数:
initial 初始化大小
next 下一个区大小
pctincrease 区大小增量
minextents 最小区数(本地管理)
maxextents 最大区数(本地管理)
4。创建B…TREE索引:
CREATE INDEX owner。index_name
ON owner。table_name(col_list)
PCTFREE n
STORAGE(INITAL nK NEXT nK PCTINCREASE n MAXEXTENTS n )
TABLESPACE space_name;
5。索引PCTFREE的变化:
索引不存在 PCTUSED;
PCTFREE 的含义是为新的插入预留的空间,在索引创建时保留;
在索引中是没有 UPDATE的。
6。创建索引的提示:
平衡查询与 DML 操作的需求,不要建太多的索引;
将索引放在单独的表空间;
使用统一的区大小:5 块的整倍数或表空间的 MINIMUMEXTENT的大小;
第 70 页,共 106 页
…………………………………………………………Page 71……………………………………………………………
资源来自网络,仅供学习! Oracle 从入门到精通
对于大的索引考虑使用 NOLOGGING(不产生日志文件,插入时速度快,索引不需要产生日志);
索引的 INITRANS 应该比相应表的 INITRANS 设置的高一些;
7。创建位图索引:
参数: create_bitmap_areasize 在创建位图索引之前为其分配区域。
CREATE BITMAP INDEX owner。index_name
ON owner。table_name(col_list)
PCTFREE 30
STORAGE(INITAL 200K NEXT 200K PCTINCREASE 0 MAXEXTENTS 50)
TABLESPACE space_name;
8。改变索引参数:
alter index index_name storage(NEXT 400K MAXEXTENTS 50);
高水平线(HWM):曾经被使用过的最后一块的位置,当对存储对象进行 TRUNCATE 时,
高水平线才会回到起点。
对全表扫描的时候,读到高水平线为止;
9。重建索引:
移动索引到另外的表空间;
通过清除删除掉的索引记录提高了空间的利用率,改善 PCTFREE 设置不良带来的问题;
alter index index_name rebuild tablespace space_name;
10。在线重建索引:(建议不使用)
alter index index_name rebuild online;
11。合并索引:
alter index index_name coalesce;
只能把同一个分支下的空间合并。
12。删除索引:
在数据做大量数据装载之前删除索引,之后再重建索引;
删除那些很少使用的索引,在需要的时候再创建(月底报表);
删除并重建失效的索引;
删除不需要的索引(备选);
drop index owner。index_name;
13。确定未使用的索引:
开始监视索引的使用:ALTER INDEX index_name MONITORING USAGE;
第 71 页,共 106 页
…………………………………………………………Page 72……………………………………………………………
资源来自网络,仅供学习! Oracle 从入门到精通
停止监视索引的使用:ALTER INDEX index_name NOMONITORING USAGE;
14。查看索引信息:
dba_indexes 提供索引的信息
dba_ind_columns 提供索引列的信息
23、管理口令安全和资源
profiles:是命名的口令管理和资源限制的集合;
不是物理上的文件;
profiles 通过 CREATE USER 或 ALTER USER 命令分配给用户;
可以被启用或禁用;
可以使用 DEFAULT profile;
profiles 提供的口令管理:
口令历史,保证在规定的时间和次数以后重用以有的口令;
允许最多的错误次数;
口令的过期失效;
口令的效验规则;
启动口令管理:
通过使用 profiles 建立口令管理并分配给用户;
通过 CREATE USER 或 ALTER USER 命令可以使用户的状态为 lock、unlock或是 expired;
口令的限制总是强制的;
为了启动口令管理,以 SYS 用户身份执行 utlpwdmg。sql 脚本;
存放脚本路径:oracle/ora92/rdbms/admin
ALTER USER user_name ACCOUNT LOCK; 手动锁定。
ALTER USER user_name ACCOUNT UNLOCK; 手动解锁。
ALTER USER user_name PASSWORD EXPIRED; 设置口令过期。
1。口令帐户锁定:
failed_login_attempts 在试图登陆多少次失败后,帐户被锁定。
password_lock_time 在由登陆失败的帐户被锁定的天数
2。自动锁定,可以手动解锁
3。口令的到期和过期:
password_life_time 口令到期的天数
password_grace_time 在口令到期后,从用户第一次成功登陆开始允许修改口令的天数;
4。口令历史:
password_reuse_time 口令在可以重用前必须经过的天数
password_reuse_max 口令在可以重用前必须被修改过的次数
这两个参数是互相排斥的。
第 72 页,共 106 页
…………………………………………………………Page 73……………………………………………………………
资源来自网络,仅供学习! Oracle 从入门到精通
5。口令的校验:
password_verify_function + function_name
在口令修改被确认前通过 PL/SQL 函数执行口令的复杂性校验。
6。用户提供的校验函数:
必须在 SYS用户下创建,必须遵循下面的声明:
function_name
( userid_parameter in varchar2(30)
password_parameter in varchar2(30)
old_password_parameter in varchar2(30)
)
return boolean
7。口令校验函数:
verify_function
8。创建profile口令设置:
create profile profile_name LINIT
failed_login_attempts 3
password_lock_time unlinited ……无限
password_life_time 30
password_grace_time 5
password_reuse_time 30
password_verify_function verify_function;
9。修改 profile :口令设置
alter profile DEFAULT limit
password_life_time 30
password_grace_time 5
password_reuse_time 30;
10。删除 profile: 口令设置
defaule profile 不能被删除;
cascade 从被授予的用户上移走 profile
drop profile profile_name;
drop profile profile_name cascade;
24、资源管理:
资源管理限制可以强制在会话级和调用级或者都可以强制限制;
可以通过 CREATE PROFILE 命令定义在 profiles上;
第 73 页,共 106 页
…………………………………………………………Page 74……………………………………………………………
资源来自网络,仅供学习! Oracle 从入门到精通
1。启动资源限制通过:
resource_limit 初始化参数
alter system 命令
alter system resource_limit = true/false;
2。会话级参数:
cpu_per_session 总的 CPU 时间(单位:百分之一秒)
sessions_per_user 每个用户允许的并发会话数
connect_time 每个用户的连续会话时间(单位:分)
idle_time 挂起状态时间(单位:分)
logical_reads_per_session 每个用户能够使用的数据块数
private_sga 在 SGA 的私有空间数(单位:字节,只对共享服务器有效)
3。调用级参数:
cpu_per_call 每次调用的 CPU 时间
ogical_reads_per_call 每次调用读的数据块数(物理读和逻辑读)
4。创建profile:资源配制
create profile profile_name limit
cpu_per_session 10000
sessions_per_user 2
idle_time 60
connect_time 480;
5。查看:
dba_u