关于oracle数据库(11)
事务
事务是最小的工作单元,是对数据库的若干操作,增删查改(要不就都成功,要不就都失败)
在oracle数据库中,事务是默认打开的,其他数据库都需要一条语句来打开事务,默认关闭的
事务的特征
原子性、一致性、隔离性、永久性
比如如果发生了错误(异常)
rollback; --回滚
在哪里执行就在哪里提交
在oracle里面一次连接(会话)就是一个事务
select * from student;
savepoint p1; --标记一个位置(事务保存点)
insert into student value();
savepoint p2; --标记一个位置(事务保存点)
insert into student value();
savepoint p3; --标记一个位置(事务保存点)
insert into student value();
savepoint p4; --标记一个位置(事务保存点)
insert into student value();
rollback to p1; --回退到指定位置
commit; --一旦执行commit之后,数据就是永久的了
数据库都有一个锁机制,当一个事务在修改某一条数据的时候,数据库会将被修改的那条数据锁住,不让其它事务修改
delete from student where sid='';
select * from student for update;
删除的时候可以锁,查询的时候也可以锁
序列 一个自动增长的对象
create sequence 序列名称;
create sequence sq1;
序列的使用
select sq1.nextval from dual; --每用1次就增加1
insert intd student values(sq1.nextval,'java',3);
increment by 1 --每次加几个
start with 1 --从1开始计数
nomaxvalue --不设置最大值
nocycle --一直累加,不循环
cache 10 --内存缓冲
查询当前序列sq1.currval
select sq1.currval from dual;
查询下一个序列sq1.nextval
select sq1.nextval from dual;
同义词
create synonym emp11 for emp; --给emp表取别名emp11
select * from emp11;
create synonym sq11 for sq1; --给序列sq1取别名sq11
select sq11.nextval from dual;
作用:一个表可以有多个别名;不想把真名告诉其它用户,删除别名,就查不了
drop synonym 别名; --删除别名
视图★
视图是一张虚拟表,数据来自于真实表,修改视图会影响真实表
作用:保护一些需要权限的字段不被其它用户看到;简化查询操作
建立视图
create view 视图名称 as 查询语句
create view v1 as select ename,sal from emp;
比如不想让行政部的人看到工资,但又想他管理员工(把视图的权限赋予给行政部就看不到工资了)
create view xz_emp as select empno,ename,job,hiredate,deptno from emp;
select * from xz_emp;
简化
--保存查询语句
create view student2 as
select sname,sid,cname from student s inner join myclass m on s.cid=m.cid
select * from student2
删除视图
drop view 视图名称;
索引(目录)
优化查询,提高sql语句执行性能(数据查询时,速度会提高一些)
简化磁盘读写
在逻辑上和物理上都独立于表的数据
索引只能建在列上面,每列只能建一个索引
系统会给主键建一个索引,不能手动给主键建立索引
如果每列都建一个索引,会提高查询效率,会降低增删改效率
一般是作为条件的列,比如:where后面的列 order by后面的列等
给ename列创建一个索引
create index inx_ename on emp(ename);
不需要手动调用,系统会自动使用
删除索引
drop index inx_ename;
唯一索引(确保定义索引的列中没有重复值)
create unique index 索引名 on 表名(字段名);
组合索引
create index 索引名 on 表名(字段1,字段2,...);
反向键索引(用于模糊查询的列)
create index 索引名 on 表名(字段名) reverse;
比如很长的字符串 需要模糊查询
select text from 表 where text like %张三%; --模糊查询效率比较低 少用
位图索引
适合创建在低基数列上(取值较少,重复值较多)
关于oracle数据库(11)的更多相关文章
- CentOS以及Oracle数据库发展历史及各版本新功能介绍, 便于构造环境时有个对应关系
CentOS版本历史 版本 CentOS版本号有两个部分,一个主要版本和一个次要版本,主要和次要版本号分别对应于RHEL的主要版本与更新包,CentOS采取从RHEL的源代码包来构建.例如CentOS ...
- AppFuse3.5对接oracle数据库
AppFuse是一个使用Java语言开发web应用系统的集成框架.java开发人员最头痛的事情就是面对大量的框架不知该如何选择.这些框架性能如何,兼容性如何等等都需要筛选比较.Appfuse作者Mat ...
- P6 EPPM手动安装指南(Oracle数据库)(一)
P6 EPPM手动安装指南(Oracle数据库) P6 EPPM Manual Installation Guide (Oracle Database) 1. 内容... 1 1.1. ...
- Oracle数据库的版本变迁功能对比
Oracle数据库自发布至今,也经历了一个从不稳定到稳定,从功能简单至强大的过程.从第二版开始,Oracle的每一次版本变迁,都具有里程碑意义. 1979年的夏季,RSI(Oracle公司的前身,Re ...
- oracle数据库常用SQL语句(11.29更新)
笔者日常工作中常用到的sql语句,现总结如下,留作日后查看. 1.按照两列中的最大值取 ,只取两列其中的一列 SELECT * FROM t_doc T ORDER BY GREATEST(T.Loa ...
- 探索Oracle数据库升级6 11.2.0.4.3 Upgrade12c(12.1.0.1)
探索Oracle数据库升级6 11.2.0.4.3 Upgrade12c(12.1.0.1) 一.前言: Oracle 12c公布距今已经一年有余了,其最大亮点是一个能够插拔的数据库(PD ...
- Oracle安装11.2.0.4.180116补丁及如何检查数据库安装补丁
最近做了一个安装11.2.0.4.180116补丁的实验,突然想起之前和同事讨论的一个问题:如何检查数据库安装补丁的版本,之前搜到的是去查dba_registry_history,有的说在操作系统中执 ...
- Oracle 数据库 Database Express Edition 11g Release 2 (11.2) 错误解决集锦(安装方面)
前言:第一次接触数据库,想下载个oracle试玩下(虽然听说一般大企业才用),到 官网下载 了个简易版 XE 版本,安装时要注意记住自己输入的数据库密码(口令) 还有安装路径不能含有空格(Do no ...
- Oracle 数据库语句大全
Oracle数据库语句大全 ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CH ...
随机推荐
- Aliexpress API 授权流程整理
Aliexpress API 授权流程整理 前言 我零零总总用了好几个月的时间,写了一个自用的小程序,从 Aliexpress 上抓取订单的小程序.刚开始写的时候,该API还没有开放,而且没有订单 ...
- Web开发框架对比
Web开发框架能极大地提升开发效率,下面对一些常用的框作一些更深层次的对比. JSF JSF不是极好的快速开发原型,代码生成不是内置功能,并且原型开发应用需要开发完整应用程序那么多的配置.这真的不是J ...
- 开始使用THREE.JS
开始使用THREE.JS 译序 Three.js是一个伟大的开源WebGL库,WebGL允许JavaScript操作GPU,在浏览器端实现真正意义的3D.但是目前这项技术还处在发展阶段,资料极为匮乏, ...
- php5.3.*编译出现make: *** [ext/gd/libgd/gd_compat.lo] Error 1 解决方法
升级系统,把php5.2.9升级到5.3.6,按照以前的编译参数,configure能正常通过,但是在make的时候提示: In file included from /root/php-5.3.6 ...
- 昨天CSAPP上的疑问的解答
昨天CSAPP上的疑问的解答 今天整明白了. CSAPP英文版第2版,826页,或者中文版第2版546页,有这么一段.关于多级页表的. "But if we had a 32-bit add ...
- 理解Javascript的状态容器Redux
Redux要解决什么问题? 随着 JavaScript 单页应用开发日趋复杂,JavaScript 需要管理比任何时候都要多的 state (状态). 这些 state 可能包括服务器响应.缓存数据. ...
- 在VisualStudio中显示当前的分支名
当项目多的时候,当分支多的时候,当会议多的时候. 你打开VS,你是否犹豫过,"我现在是打开的哪个分支?!!!!??!" 如果你米有犹豫过,是否有过,"FXXXXK, 我怎 ...
- NSClassFromString,NSSelectorFromString,isKingOfClass
1. NSClassFromString 这个方法判断类是否存在,如果存在就动态加载的,不存为就返回一个空对象; id myObj = [[NSClassFromString(@"MySpe ...
- Python第一天——入门Python(1)数据定义
数据类型: 什么是数据? 在计算机科学中,数据是指所有能输入到计算机并被计算机程序处理的符号的介质的总称,是用于输入电子计算机进行处理,具有一定意义的数字字母.符号和模拟量等的统称.现在计算机存储和处 ...
- BHuman文档结构
Chapter 2 : a short introduction how to build the code including the required software and how to ru ...