博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle系列--基础理论
阅读量:4328 次
发布时间:2019-06-06

本文共 1929 字,大约阅读时间需要 6 分钟。

一、数据库系统架构:

      外层(External Level)外层是提供给用户直接操作使用的

      概念层(Conceptual Level)用来描述数据库中存放数据的类型、表之间的关系、高级的数据模型、用户的权限

内层(Internal Level)主要用来描述实际的数据库存储结构

映射(Mapping)提供需求和转换所需数据的过程

数据独立性(Data Independence):当数据有所变动时,不必改变其他的数据结构

二、设计数据库的范式

第一范式

第二范式

第三范式

BCNF范式

三、数据库管理

system

ora123

startup open orcl --权限不足

conn sys as sysdba 

ora123 --已连接

startup open orcl  --无法启动

shutdown immediate

startup open orcl

扩展:以nomount方式打开数据库

以mount方式装载数据库

以parallel模式打开数据库

以exclusive模式打开数据库

三、关闭数据库4种方式:(请不要在oracle11g和oracle10g上测试shutdown ,shutdown normal命令,)

shutdown normal 申请进入的进程拒绝,正在运行的进程正常运行

shutdown immediate 比如有人正在买盗版光碟,此时工商执法人员来了,卖盗版光碟的小贩赶紧将钱退给此人,之后逃跑

shutdown abort 比如商场着火了,已经没有时间做任何事情了,得赶紧逃命了

shutdown transactional 申请进入的进程拒绝,正在运行但是不出来事务的杀死,正在处理事务的正常运行

四、设置数据库

五、建立数据库

约束条件的操作:启动、关闭、删除、验证

视图(View):

      优点:它能限制数据的存取

              它能让复杂的查询简单化

              它为项目用户及应用程序提供数据的独立性

              它能让使用者根据自己的特定标准存取数据

 如果建立的是一个简单视图,则可以直接指向DML语法

 如果建立的是一个复杂视图,则在执行DML时,有以下限制:

       1、不能添加数据

        2、不能修改数据

        3、不能删除数据

序列(Sequence)

六、事务处理:

事务本身具有4个ACID特征:原子性,一致性,隔离性或者独立性,持久性

事务只能针对DML操作语言实现,对DDL操作不起任何作用

锁:--行级锁定(记录锁定)  隐式地实现记录的锁定   被称为排他锁

     --表级锁定  与行级锁定的自动锁定相比,该锁定需要用户明确地使用LOCK TABLE语句手工锁定

           表级锁定又分为:行共享锁 ROW SHARE

                                 行排他锁  ROW EXCLUSIVE

                                 共享锁 SHARE

                                 共享排它锁 

                                 排它锁

解除锁定:ALTER SYSTEM KILL SESSION ‘SID,SERIAL#’    

SID和SERIAL#需要通过管理员利用v$locked_object, v$session两个数据字典查询得到

替代变量

ACCEPT命令只能在脚本文件中使用:先建立一个脚本文件,而后使用" @ "命令执行脚本;使用ACCEPT命令时替代变量不区分大小写

数据字典:静态数据字典

              动态数据字典

闪回技术(FlashBack):是oracle10g之后提供的一种新的数据保障措施,类似于windows操作系统的回收站功能

FLASHBACK TABLE 表名称 TO BEFORE DROP;

如果要彻底删除表,则执行语句:DROP TABLE 表名称 PURGE;

清空回收站:PURGE recyclebin;

七、索引:

B树索引(基于二叉树排序)

降序索引

位图索引:如果某一列上的数据都属于低基数列的时候使用

CREATE  BITMAP INDEX emp_deptno_ind ON emp(deptno);   在deptno字段上设置位图索引

函数索引

CREATE INDEX emp_ename_ind ON emp(LOWER(ename));

同义词:CREATE [PUBLIC] SYNONYM myemp for aa.emp;

八、Oracle 伪列:

NEXTVAL

CURRVAL

SYSDATE

SYSTIMESTAMP

ROWNUM  除了简单查询外,ROWNUM也同样用于复杂查询的操作

ROWID  oracle默认为每条记录分配一个唯一的地址编号,这个编号就是通过ROWID来表示的,所有的数据都利用ROWID进行数据定位

 

转载于:https://www.cnblogs.com/wangwanchao/p/4971183.html

你可能感兴趣的文章
dockerfile_nginx+PHP+mongo数据库_完美搭建
查看>>
Http协议的学习
查看>>
【转】轻松记住大端小端的含义(附对大端和小端的解释)
查看>>
设计模式那点事读书笔记(3)----建造者模式
查看>>
ActiveMQ学习笔记(1)----初识ActiveMQ
查看>>
Java与算法之(2) - 快速排序
查看>>
Windows之IOCP
查看>>
机器学习降维之主成分分析
查看>>
CTP2交易所成交回报
查看>>
WebSocket & websockets
查看>>
openssl 升级
查看>>
ASP.NET MVC:通过 FileResult 向 浏览器 发送文件
查看>>
CVE-2010-2883Adobe Reader和Acrobat CoolType.dll栈缓冲区溢出漏洞分析
查看>>
使用正确的姿势跨域
查看>>
AccountManager教程
查看>>
Android学习笔记(十一)——从意图返回结果
查看>>
算法导论笔记(四)算法分析常用符号
查看>>
ultraedit激活
查看>>
总结(6)--- python基础知识点小结(细全)
查看>>
亿级曝光品牌视频的幕后设定
查看>>