第二章   Oracle数据库应用
2.1 表空间和用户权限下管理
    2.1.1 表空间
        2.1.1.1 分类:
            永久性表空间
            临时性表空间
            撤销表空间
        2.1.1.2 表空间的目的
            对不同的用户分配不同的空间
            将不同的数据文件创建到不同的磁盘
        2.1.1.3 创建表空间
            2.1.1.3.1 语法:
                CREATE TABLESPACE tablespacename
                DATAFILE 'filename' [SIZE integet [K|H]]
                [AUTOEXTEND [OFF | ON]];
        2.1.1.4 删除表空间
            2.1.1.4.1 语法:
                DROP TABLESPACE tablespacename;
    2.1.2 自定义用户权限
        2.1.2.1 Sys:超级用户
        2.1.2.2 System:系统管理员
        2.1.2.3 Scott:示范用户
    2.1.3 数据库权限管理
        2.1.3.1 系统权限:
            2.1.3.1.1 定义:在数据库中执行某种系统级别的权限操作
            2.1.3.1.2 常用系统权限:
                        CREATE SESSION:连接到数据库
                        CREATE TABLE:创建表
                        CREATE VIEW:创建实体
                        CREATE SEQUENCE:创建序列
        2.1.3.2 对象权限
            2.1.3.2.1 定义:用户对数据库中具体对象所拥有的权限
            2.1.3.2.2 获取权限途径:
                      CONNECT:连接到数据库的用户,特别是不需要创建表的用户,通常授予该权限;
                      RESOURCE:更为可靠的和正式的数据库用户可授予该角色;
                      DBA:数据库管理员,用于管理数据库的最高权限;
            2.1.3.2.3 授予权限的语法:
                      GRANT 权限 | 角色 TO 用户;
            2.1.3.2.4 撤销权限的语法:                            
                      REVOKE 权限 | 角色 FROM 用户;
            2.1.3.2.5 数据库用户安全设计原则
                        1、按最小分配原则
                        2、用户分为管理,应用,维护,备份四类
                        3、不允许使用Sys和system用户建立数据库应用对象
                        4、禁止GRANT dba TO user;
2.2 序列
    2.2.1 创建序列
            语法:
                CREATE SEQUENCE sequence_name
                [START WITH integer]    ---->指定要生成的第一个序列号
                [INCREMENT BY integer]    ---->指定序列号之间的间隔
                [MAXVALUE integer | NOMAXVALUE]    ---->指定序列可以生成的最大值,如果指定了NOMAXVALUE ,最大为10*27
                [MINVALUE integer | NOMINVALUE]    ---->指定序列可以生成的最小值,如果指定了NOMINVALUE ,最小为10*26
                [CYCLE | NOCYCLE]    ---->预先分配一组序列号
                [CACHE integer | NOCACHE];    ---->不会分配一组序列号,如果两个都忽略,系统默认缓存20个序列号
    2.2.2 访问序列
            NEXTVAL:第一次使用时,返回该序列的初始值
            CURRVAL:返回序列的当前值
    2.2.3 更改序列
            语法:
                ALTER SEQUENCE [schema.]sequence_name
                [INCREMENT BY integer]
                [MAXVALUE integer | NOMAXVALUE]
                [MINVALUE integer | NOMINVALUE]
                [CYCLE | NOCYCLE]
                [CACHE integer | NOCACHE];
            注:不能修改序列的START WITH参数,修改序列时,应注意升序序列的最小值应小于最大值;
    2.2.3 删除序列
            语法:
                DROP SEQUENCE [schema.]sequence_name
                例:DROP SEQUENCE seql;--->从数据库中删除seql序列
    2.2.3 使用序列    
2.3 同义词
    2.3.1 同义词的用途
        1.简化SQL语句
        2.隐藏对象的名称和所有者
        3.位分布式数据库的远程对象提供了位置透明性
        4.提供对对象的公共访问
    2.3.2 同义词分类
        2.3.2.1 私有同义词
            1、创建语法:
                CREATE [OR REPLACE] SYNONYM [schema.]synonym_name--->同义词名称
                FOR [schema.]object_name    --->在同义词存在的情况下替换该同义词
        2.3.2.2 公有同义词
            1、创建语法:
                CREATE [OR REPLACE] PUBLIC SYNONYM [schema.]synonym_name
                FOR [schema.]object_name
        2.3.2.3 私有同义词和公有同义词的区别            
            1、私有同义词只能在当前模式西访问,不能和当前模式的对象同名
            2、公有同义词可被所有的数据库用户访问            
            3、创建同义词需要拥有一定的权限
    2.3.2 删除同义词
        语法:
            DROP [PUBLIC] SYNONYM [schema.]synonym_name
2.4 序列
    2.4.1 什么是序列?
        定义:序列是与表关联的可选结构,是一种快速访问数据库的途径,可提高数据库性能
    2.4.2 序列的分类
        2.4.2.1、分区或非分区索引        单列或组合索引
        2.4.2.2、B树索引(标识索引)        唯一或非唯一索引
        2.4.2.3、正常或反向键索引        基于函数索引
        2.4.2.4、位图索引
        2.4.2.5 B树索引
                语法:
                    CREATE [UNIQUE] INDEX index_name ON table_name(column_list)
                    [TABLESPACE tablespace_name]
                    UNIQUE:指定唯一索引
                    index_name:创建索引的名称
                    column_list:在上创建索引的列名列表,可基于多列
        2.4.2.6 唯一或非唯一索引
                唯一索引定义:定义索引的列中任何两行都没有重复值
                非唯一索引定义:    单个关键字可以有多个与其关联的行
        2.4.2.7 反向键索引    
                定义:保存序列顺序的同时反转索引列的字节
        2.4.2.8 位图索引
                优点:1、对于大批即时查询
                      2、相比其他索引技术占用空间减少
                      3、配置低的终端硬件上,性能也很好
        2.4.2.9 其他索引
                    组合索引:在表内多列上创建,索引列不必和表中的列顺序一样
                    基于函数索引:使用的函数或表达式时间正在建立的索引的标识的一列或多列,则创建基于函数索引
    2.4.3 创建序列原则
            1~8 教材58~59页
    2.4.4  删除索引
        2.4.4.1 DROP INDEX语句
                例:DROP INDEX 索引名;
        2.4.4.2 何时删除索引
                1、应用程序不再需要索引
                2、执行批量加载钱删除索引
                3、索引已经损坏
    2.4.5  重建索引    
        2.4.5.1  ALTER INDEX...REBUILD语句
                例:ALTER INDEX 索引名 REBUILD NOREVERSE;
        2.4.5.2    何时重建索引
                1、用户表被移动到新的表空间后
                2、索引中已包含很多已删除的项
                3、需将现有的正常索引转换成反向键索引
2.5 分区表
    2.5.1 什么分区表
        2.5.1.1 定义:把一个表中的所有行分为几个部分,并储存在不同的位置,被分区的表称为分区表
        2.5.1.2 优点:
                    1、改善表的查询
                    2、表更容易管理
                    3、便于备份和恢复
                    4、提高数据安全性
    2.5.2 分区表的分类
        2.5.2.1、范围分区
        2.5.2.2、列表分区
        2.5.2.3、散列分区
        2.5.2.4、复合分区
        2.5.2.5、间隔分区
        2.5.2.6、虚拟分区

--样例

--创建表空间
  CREATE TABLESPACE worktbs
        DATAFILE 'D:\Berlin\Y2T198\WORKTBS01.DBF'
        SIZE 10M
        AUTOEXTEND ON;
--删除表空间
    DROP TABLESPACE worktbs;   
--创建用户
    CREATE USER martin
    IDENTIFIED BY martinpwd
    DEFAULT TABLESPACE worktbs;
    --TEMPORARY TABLESPACE temp;
--修改口令
    ALTER USER martin
    IDENTIFIED BY mpwd;
--删除用户
    DROP USER martin CASCADE;
--授予connect和resource两个角色
    GRANT CONNECT,RESOURCE TO martin;
--撤销connect和resource两个角色
    REVOKE CONNECT,RESOURCE FROM martin;
--允许查看emp表中的记录
    GRANT SELECT ON scott.emp TO martin;
--允许更新emp表中的记录
    GRANT UPDATE ON scott.emp TO martin;
--创建序列
    CREATE SEQUENCE seq1
        START WITH 10  --指定要生成的第一个序列号
        INCREMENT BY 1  --指定序列号之间的间隔
        MAXVALUE 2000 --指定序列可以生成的最大值,如果指定了NOMAXVALUE ,最大为10*27       
        NOCYCLE --预先分配一组序列号
        CACHE 30;  --不会分配一组序列号,如果两个都忽略,系统默认缓存20个序列号
--插入数据
        CREATE TABLE toys
        (
               toyid NUMBER(5),
               toyname VARCHAR2(20),
               toyprice NUMBER(4,2)
        );
    INSERT INTO toys(toyid,toyname,toyprice)
           VALUES(seq1.NEXTVAL,'TWENTY',25);
     INSERT INTO toys(toyid,toyname,toyprice)
           VALUES(seq1.NEXTVAL,'MAGIC PENCIL',75);
    --查询数据
    SELECT * FROM toys;
    --查询当前序列的值
    SELECT seq1.CURRVAL FROM dual;
--更改序列
    ALTER SEQUENCE seq1
        INCREMENT BY 2
        MAXVALUE 3000
        NOCYCLE
        CACHE 35;
--删除序列
        DROP SEQUENCE seq1;
--创建私有同义词SY_EMP
        CREATE SYNONYM SY_EMP FOR A_hr.employee
        --访问同义词
        SELECT * FROM SY_EMP;
 --创建公有同义词public_sy_emp
        CREATE PUBLIC SYNONYM public_sy_emp FOR employee
        --访问同义词
        SELECT * FROM public_sy_emp;   
--删除同义词
        DROP SYNONYM A_oe.SY_EMP;
        
        DROP PUBLIC SYNONYM A_hr.public_sy_emp;    
--创建普通索引
        CREATE UNIQUE INDEX index_unique_grade ON salgrade(grade);
--创建反向索引
        CREATE INDEX index_reverse_empno ON employee(empno) REVERSE;
--创建位图索引
        CREATE BITMAP INDEX index_bit_job ON employee(job);
--创建大写函数索引
        CREATE INDEX index_ename ON employee(UPPER(ename));
--删除索引
        DROP INDEX index_reverse_empno;
--重建索引
        --将反向键索引更改为正常的B树索引
        ALTER INDEX index_reverse_empno REBUILD NOREVERSE;
--分区

CREATE TABLE sales2
        (
               sales_id NUMBER,--销售流水号
               product_id VARCHAR2(5),--产品id
               sales_date DATE NOT NULL,--销售日期
               sales_cost NUMBER(10),--销售金额
               areacode VARCHAR2(5)--销售区域
        )
        PARTITION BY RANGE(sales_date)
        (
                  PARTITION p1 VALUES LESS THAN (to_date('2012-01-01','yyyy-mm-dd')),
                  PARTITION p2 VALUES LESS THAN (to_date('2012-02-01','yyyy-mm-dd')),
                  PARTITION p3 VALUES LESS THAN (to_date('2012-03-01','yyyy-mm-dd')),
                  PARTITION p4 VALUES LESS THAN (to_date('2012-04-01','yyyy-mm-dd')),
                  PARTITION p5 VALUES LESS THAN (MAXVALUE)
        );
        --查看第三季度的数据
                 SELECT * FROM sales2 PARTITION(p3);
        --删除第三季度的数据
                 DELETE FROM sales2 PARTITION(p3);
--创建间隔分区
          CREATE TABLE sales3
        (
               sales_id NUMBER,--销售流水号
               product_id VARCHAR2(5),--产品id
               sales_date DATE NOT NULL,--销售日期
               sales_cost NUMBER(10),--销售金额
               areacode VARCHAR2(5)--销售区域
        )
         PARTITION BY RANGE(sales_date)
         INTERVAL(NUMTOYMINTERVAL(3,'month'))
         (PARTITION p1 VALUES LESS THAN (to_date('2012-01-01','yyyy/mm/dd')))        
          --插入数据
          INSERT INTO sales2 VALUES(1,'a',to_date('2013-08-1'),10,'1');
          --查询分区情况
          SELECT table_name,partition_name
          FROM User_Tab_Partitions
          WHERE table_name=UPPER('sales3');
          --查询分区数据
          SELECT * FROM sales3 PARTITION(sys_p2);

第二章 Oracle数据库应用的更多相关文章

  1. 第一章 oracle数据库基础

    第一章   oracle数据库基础 1.oracle简介-->数据库管理系统    1.1:数据库    1.2:全局数据库名    1.3:数据库实例    1.4:表空间    1.5:数据 ...

  2. Oracle学习笔记--第2章 oracle 数据库体系结构

    第2章 oracle 数据库体系结构 目录: ————————————— 2.1物理存储结构 2.1.1数据文件 2.2.2控制文件 2.1.3重做日志文件 2.1.4其他文件 2.2逻辑存储结构 2 ...

  3. MySQL篇,第二章:数据库知识2

    MySQL 数据库 2 名词介绍 1.DB(Database) DB就是数据库,存储数据的仓库 2.DBMS(Database Management System) 数据库管理系统 管理数据库的软件, ...

  4. ORACLE数据库编程

    第一章 Oracle数据库基本概念 一.介绍 Oracle数据库系统是美国Oracle(甲骨文)公司提供的以分布式数据库为 核心的一组软件产品,是目前最流行的客户/服务器(Client/Server, ...

  5. oracle数据库表空间扩容方法

    1. 先查询表空间在物理磁盘上存放的位置,注意使用sysdba的账号登陆. SELECT tablespace_name, file_id, file_name, ), ) total_space F ...

  6. 《Oracle Database 12c DBA指南》第二章 - 安装Oracle和创建数据库(2.2 安装数据库软件)

    当前关于12c的中文资料比较少,本人将关于DBA的一部分官方文档翻译为中文,很多地方为了帮助中国网友看懂文章,没有按照原文句式翻译,翻译不足之处难免,望多多指正. 2.2 安装数据库软件 这部分简短讲 ...

  7. 《Oracle Database 12c DBA指南》第二章 - 安装Oracle和创建数据库(2.1 安装Oracle数据库软件和创建数据库概览)

    当前关于12c的中文资料比较少,本人将关于DBA的一部分官方文档翻译为中文,很多地方为了帮助中国网友看懂文章,没有按照原文句式翻译,翻译不足之处难免,望多多指正. 2.1 安装Oracle数据库软件和 ...

  8. ORACLE AUTOMATIC STORAGE MANAGEMENT翻译-第二章 ASM instance(1)

    第二章  ASM INSTANCE ASM的类型,例如可以: 10g后ORACLE instance 类型增加了一个ASM种类.参数INSTANCE_TYPE=ASM进行设置. ASM实例启动命令: ...

  9. 【书评:Oracle查询优化改写】第二章

    [书评:Oracle查询优化改写]第二章 BLOG文档结构图 在上一篇中http://blog.itpub.net/26736162/viewspace-1652985/,我们主要分析了一些单表查询的 ...

随机推荐

  1. 前端总结·基础篇·JS(一)五大数据类型之字符串(String)

    前端总结系列 前端总结·基础篇·CSS(一)布局 前端总结·基础篇·CSS(二)视觉 前端总结·基础篇·CSS(二)补充 前端总结·基础篇·JS(一)五大数据类型之字符串(String) 目录 这是& ...

  2. 用smarty来做简易留言系统,明细步骤简单操作

    留言信息是之前用php做过的一个例子,现在把它用smarty模板来做 大概是这样子 点击发布信息 然后填写内容,发送后会返回表格,写的内容都会出现在表格里 数据库的数据是这样的: 先建两个文件.php ...

  3. Android中使用开源框架citypickerview实现省市区三级联动选择

    1.概述 记得之前做商城项目,需要在地址选择中实现省市区三级联动,方便用户快速的填写地址,当时使用的是一个叫做android-wheel 的开源控件,当时感觉非常好用,唯一麻烦的是需要自己整理并解析省 ...

  4. Eclipse标准版安装J2EE插件

    WTP 使用Eclipse IDE for Java EE Developers是非常方便,但是太大,我喜欢按需配置.首先我们来了解什么是WTP. WTP(Web Tools Platform )项目 ...

  5. DOM基础(三)

    对于DOM来说,知识点其实并不多,要理解DOM并不难,难的是会用.可能有的人看见DOM获取元素要这么长一串单词就觉得生无可恋了.不过说实在的,如果你能理解他的意思跟用法.而且稍微再有点英语基础的话,D ...

  6. [HDOJ2572]终曲

    Problem Description 最后的挑战终于到了!站在yifenfei和MM面前的只剩下邪恶的大魔王lemon一人了!战胜他,yifenfei就能顺利救出MM.Yifenfei和魔王lemo ...

  7. Java中整形、浮点、字符之间的转换

    如:String s = "123";int num = Integer.parseInt(s);注意:当应用程序试图将字符串转换成一种数值类型,但该字符串不能转换为适当格式时,会 ...

  8. mybatis基础学习1---(配置文件和sql语句)

    1:配置文件(主要配置文件) 2:配置文件(引入) 3:sql语句解析: <mapper namespace="/"> <!-- 1 -->根据id查对象 ...

  9. Apache网页的缓存时间

    配置网页缓存时间概述 通过mod_expires模块配置Apache,使网页能在客户端浏览器缓存一段时间,以避免重复请求,减轻服务端工作压力. 启用mod_expires模块后,会自动生成页面头部信息 ...

  10. 【树莓派】制作树莓派最小镜像:img裁剪瘦身

    制作树莓派镜像,可以参考这篇文章:http://blog.csdn.net/talkxin/article/details/50456282 摘录部分要点内容如下(如果作者不允许转载,请联系即删除): ...