Posted by weilm on 2012-05-09 01:06 下午
|
一、ORACLE的表的分类:
1、REGULAR TABLE:普通表,ORACLE推荐的表,使用很方便,人为控制少。
2、PARTITIONED TABLE:分区表,人为控制记录的分布,将表的存储空间分为若干独立的分区,记录按一定的规则存储在分区里。适用于大型的表。
二、建表
1、 CREATE TABLE 表名 (EMPNO NUMBER(2),NAME VARCHAR2(20)) PCTFREE 20 PCTUSED 50 STORAGE (INITIAL 200K NEXT 200K MAXEXTENTS 200 PCTINCREASE 0) TABLESPACE 表空间名称 [LOGGING|NOLOGGING]所有的对表的操作都要记入REDOLOG,ORACLE建议使用NOLOGGING; [CACHE|NOCACHE]:是否将数据按照一定的算法写入内存。
2、关于PCTFREE 和PCTUSED
A、行迁移和行链接 B、PCTFREE:制止INSERT,为 UPDATE留FREE 空间 C、PCTUSED:为恢复INSERT操作,而设定的。
三、拷贝一个已经存在的表: CREATE TABLE 新表名 STORAGE(。。) TABLESPACE 表空间 AS SELECT * FROM 老表名 ; 当老表存在约束,触发的时候,不会拷过去。
四、修改表的参数 ALTER TABLE 名称 PCTFREE 20 PCTUSED 50 STOAGE(MAXEXTENTS 1000);
五、手工分配空间: ALTER TABLE 名称 ALLOCATE EXTENT(SIZE 500K DATAFILE '。。'); 1、SIZE选项,按照NEXT分配 2、表所在表空间与所分配的数据文件所在的表空间必须一样。
六、水线 1、水线定义了表的数据在一个BLOCK中所达到的最高的位置。 2、当有新的记录插入,水线增高 3、当删除记录时,水线不回落 4、减少查询量
七、如何回收空间: ALTER TABLE 名称 DEALLOCATE UNUSED [KEEP 4[M|K]] 1、当空间分配过大时,可以使用本命令 2、如果没有加KEEP,回收到水线 3、如果水线《MINEXTENTS的大小回收到MINEXTENTS所指定的大小
八、TRUNCATE 一个表 TRUNCATE TABLE 表名,表空间截取MINEXTENT,同时水线重置。
九、DROP 一个表 DROP TABLE 表名 [CASCADE CONSTRAINTS] 当一个表含有外键的时候,是不可以直接DROP的,加CASCADE CONSRIANTS将外键等约束一并删掉。
十、信息获取 1、dba_object 2 dba_tables:建表的参数 3 DBA_SEGMENTS: 组合查询的连接字段:DBA_TABLES的table_name dba_ojbect的object_name dba_segments的SEGMENT_NAME
第十一章:索引的管理
一、索引的分类: 1、逻辑上: 单列索引 复合索引 唯一索引 非唯一索引 2、物理上: B-TREE OR BITMAP B-TREE (NORMAL和反向索引)
二、CREATE INDEX CREATE INDEX 名称 ON 表名(列名) PCTFREE 30 STORAGE(。。。。。) TABLESPACE 名称 没有定义PCTUSED:索引是按照一定存储的,如果通过PCTUSED允许恢复对BLOCK的INSERT操作,可能影响INDEX的效率。 三、建立索引的注意事项 1、索引对查询性能有提高,但对DML语句有影响。 2、索引也应该放在一个专用的表空间 3、定义索引的EXTENT的大小时,=5*DB BLOCK 4、建立索引时,应采用 NOLOGGING 方式。
四、修改索引 ALTER INDEX 名称 STORAGE(新值)
五、分配空间给索引 1、ALTER INDEX 名称 ALLOCATE EXTENT(SIZE 200K DATAFILE '。。')
六、重建索引
1、提高查询性能
2、当一个索引重建时,老的索引会在新索引建立完成后,被删除。
3、新索引建立过程中,老的索引仍可用于查询。
4、硬盘的开销大,
七、DROP一个索引 DROP INDEX 名称
八、信息获取 1、DBA_INDEXES:建索引的参数 2、DBA_IND_COLUMNS:
第十二章:用户的管理
一、ORACLE的安全域
1、TABLESPACE QUOTAS:表空间的使用定额
2、DEFAULT TABLESPACE:默认表空间
3、TEMPORARY TABLESPACE:指定临时表空间。
4、ACCOUNT LOCKING:用户锁
5、RESOURCE LIMITE:资源限制
6、DIRECT PRIVILEGES:直接授权
7、ROLE PRIVILEGES:角色授权先将应用中的用户划为不同的角色,
二、创建用户时的清单:
1、选择一个用户名称和检验机制:A,看到用户名,实际操作者是谁,业务中角色。
2、选择合适的表空间:
3、决定定额:
4、口令的选择:
5、临时表空间的选择:先建立一个临时表空间,然后在分配。不分配,使用SYSTEM表空间 6、CREATE USER
7、授权:A,用户的工作职能 B,用户的级别
三、用户的创建:
1、命令: CREATE USER 名称 IDENTIFIED BY 口令 DEFAULT TABLESPACE 默认表空间名 TEMPOARAY TABLESPACE 临时表空间名 QUOTA 15M ON 表空间名 [PASSWORD EXPIRE]:当用户第一次登陆到ORACLE,创建时所指定的口令过期失效,强迫用户自己定义一个新口令。 [ACCOUNT LOCK]:加用户锁 QUOTA UNLIMITED ON TABLESPACE:不限制,有多少有多少。 [PROFILE 名称]:受PROFILE文件的限制。
四、如何控制用户口令和用户锁 1、强迫用户修改口令:ALTER USER 名称 IDENTIFIED BY 新口令 PASSWORD EXPIRE; 2、给用户加锁:ALTER USER 名称 ACCOUNT [LOCK|UNLOCK] 3、注意事项: A、所有操作对当前连接无效 B、1的操作适用于当用户忘记口令时。
五、更改定额 1、命令:ALTER USER 名称 QUOTA 0 ON 表空间名 ALTER USER 名字 QUOTA (数值)K|M|UNLIMITED ON 表空间名; 2、使用方法: A、控制用户数据增长 B、当用户拥有一定的数据,而管理员不想让他在增加新的数据的时候。 C、当将用户定额设为零的时候,用户不能创建新的数据,但原有数据仍可访问。
六、DROP一个USER 1、DROP USER 名称 适合于删除一个新的用户 2、DROP USER 名称 CASCADE: 删除一个用户,将用户的表,索引等都删除。 3、对连接中的用户不好用。
七、信息获取: 1、DBA_USERS:用户名,状态,加锁日期,默认表空间,临时表空间 2、DBA_TS_QUOTAS:用户名,表空间名,定额。 两个表的连接字段:USERNAME GRANT CREATE SESSION TO 用户名
第十三章:PROFILE的管理(资源 文件)
一、PROFILE的管理内容: 1、CPU的时间 2、I/O的使用 3、IDLE TIME(空闲时间) 4、CONNECT TIME(连接时间) 5、并发会话数量 6、口令机制:
二、DEFAULT PROFILE: 1、所有的用户创建时都会被指定这个PROFILE 2、DEFAULT PROFILE的内容为空,无限制
三、PROFILE的划分: 1、CALL级LIMITE: 对象是语句: 当该语句资源使用溢出时: A、该语句终止 B、事物回退 C、SESSION连接保持 2、SESSION级LIMITE: 对象是:整个会话过程 溢出时:连接终止
四、如何管理一个PROFILE 1、CREATE PROFILE 2、分配给一个用户 3、象开关一样打开限制。
五、如何创建一个PROFILE: 1、命令:CREATE PROFILE 名称 LIMIT SESSION_PER_USER 2 CPU_PER_SESSION 1000 IDLE_TIME 60 CONNECT_TIME 480
六、限制参数: 1、SESSION级LIMITE: CPU_PER_SESSION:定义了每个SESSION占用的CPU的时间: (1/100 秒) 2、SESSION_PER_USER:每个用户的并发连接数 3、CONNECT_TIME:一个连接的最长连接时间(分钟) 4、LOGICAL_READS_PER_SESSION: 一次读写的逻辑块的数量 5、CALL级LIMITE CPU_PER_CALL:每个语句占用的CPU时间 LOGICAL_READS_PER_CALL:
七、分配给一个用户: CREATE USER 名称。。。。。。 PROFILE 名称 ALTER USER 名称 PROFILE 名称
八、打开资源限制: 1、RESOURCE_LIMT:资源文件中含有 2、ALTER SYSTEM SET RESOURCE_LIMIT=TRUE; 3、默认不打开
九、修改PROFIE的内容: 1、ALTER PROFILE 名称参数 新值 2、对于当前连接修改不生效。
十、DROP一个PROFILE 1、DROP PROFILE 名称 删除一个新的尚未分配给用户的PROFILE, 2、DROP PROFILE 名称 CASCADE 3、注意事项 A、一旦PROFILE被删除,用户被自动加载DEFAULT PROFILE B、对于当前连接无影响 C、DEFAULT PROFILE不可以被删除
十一、信息获取: 1、DBA_USERS: 用户名,PROFILE 2、DBA_PROFILES:
|
|