oracle中事务处理
什么是事务
事务用于保证数据的一致性,它由一组相关的dml语句组成,该组的dml(数据操作语言:增删改,没有查询)语句要么全部成功,要么全部失败。 如:网上转账就是典型的要用事务来处理,用于保证数据的一致性。
dml 数据操作语言 事务和锁
当执行事务操作时(dml语句),oracle会在被作用的表上加锁,防止其它用户应用程序修改表的结构。这里对我们的用户来来讲是非常重要的。
.....其它进程排序,知道1号进程完成,锁打开(锁是一个互斥对象),2号进程进入。依次进行,如果有进程级别较高的,可以插队。 提交事务
当执行用commit语句可以提交事务。当执行了commit语句之后,会确认事务的变化、结束事务。删除保存点、释放锁,当使用commit语句结束事务之后,其它会话将可以查看到事务变化后的新数据。
保存点就是为回退做的。保存点的个数没有限制 回退事务
在介绍回退事务前,我们先介绍一下保存点(savepoint)的概念和作用。保存点是事务中的一点。用于取消部分事务,当结束事务时,会自动的删除该事务所定义的所有保存点。当执行rollback时,通过指定保存点可以回退到指定的点,这里我们作图说明。 事务的几个重要操作
.设置保存点 savepoint a
.取消部分事务 rollback to a
.取消全部事务 rollback 注意:这个回退事务,必须是没有commit提交的;如果事务提交了,那么无论你刚才做了多少个保存点,都统统没有,rollback to a会提示没有创建保存点a. 没有提交则事物的变化只是一直积累积累,只有提交了,删除保存点、释放锁,当使用commit语句结束事务之后,其它会话将可以查看到事务变化后的新数据
如果没有手动执行commit,而是exit了,那么会自动提交 java程序中如何使用事务
在java操作数据库时,为了保证数据的一致性,比如账户操作()从一个账户中减掉10$()在另一个账户上加入10$,我们看看如何使用事务?
Java代码
.package com.sp;   .import java.sql.Connection;   
.import java.sql.DriverManager;   
.import java.sql.ResultSet;   
.import java.sql.Statement;   .public class TestTrans {   .    public static void main(String[] args) {   
.        try {   .            // 1.加载驱动   
.            Class.forName("oracle.jdbc.driver.OracleDriver");   .            // 2.得到连接   
.            Connection ct = DriverManager.getConnection(   
.                    "jdbc:oracle:thin:@127.0.0.1:1521:orcl", "scott", "tiger");   .            Statement sm = ct.createStatement();   
.  
.            // 从scott的sal中减去100   
.            sm.executeUpdate("update emp set sal=sal-100 where ename='SCOTT'");   
.  
.            int i =  / ;   //抛出异常
.  
.            // 给smith的sal加上100   
.            sm.executeUpdate("update emp set sal=sal+100 where ename='SMITH'");   
.  
.            // 关闭打开的资源   
.            sm.close();   
.            ct.close();   
.        } catch (Exception e) {   
.            e.printStackTrace();   
.        }   
.  
.    }   
.  
.}  
运行,会出现异常,查看数据库,SCOTT的sal减了100,但是SMITH的sal却不变,很可怕。。。
我们怎样才能保证,这两个操作要么同时成功,要么同时失败呢?
Java代码
.package com.sp;   
.  
.import java.sql.Connection;   
.import java.sql.DriverManager;   
.import java.sql.SQLException;   
.import java.sql.Statement;   
.  
.public class TestTrans {   
.  
.    public static void main(String[] args) {   
.        Connection ct = null;   
.        try {   
.            // 1.加载驱动   
.            Class.forName("oracle.jdbc.driver.OracleDriver");   
.  
.            // 2.得到连接   
.            ct = DriverManager.getConnection(   
.                    "jdbc:oracle:thin:@127.0.0.1:1521:orcl", "scott", "tiger");   
.  
.            // 加入事务处理   
.            ct.setAutoCommit(false);// 设置不能默认提交   
.  
.            Statement sm = ct.createStatement();   
.  
.            // 从scott的sal中减去100   
.            sm.executeUpdate("update emp set sal=sal-100 where ename='SCOTT'");   
.  
.            int i =  / ;   
.  
.            // 给smith的sal加上100   
.            sm.executeUpdate("update emp set sal=sal+100 where ename='SMITH'");   
.  
.            // 提交事务   
.            ct.commit();   
.  
.            // 关闭打开的资源   
.            sm.close();   
.            ct.close();   
.        } catch (Exception e) {   
.            // 如果发生异常,就回滚   
.            try {   
.                ct.rollback();   
.            } catch (SQLException e1) {   
.                e1.printStackTrace();   
.            }   
.            e.printStackTrace();   
.        }   
.  
.    }   
.  
.}  
再运行一下,会出现异常,查看数据库,数据没变化。
 只读事务
只读事务是指只允许执行查询的操作,而不允许执行任何其它dml操作的事务,使用只读事务可以确保用户只能取得某时间点的数据。假定机票代售点每天18点开始统计今天的销售情况,这时可以使用只读事务。在设置了只读事务后,尽管其它会话可能会提交新的事务,但是只读事务将不会取得最新数据的变化,从而可以保证取得特定时间点的数据信息。 设置只读事务(SQL*Plus里面输入set transaction read only,这后面的查询只是之前的,刚刚更新的数据查不出来)(只有commit数据才是真的提交到数据库)
sql函数的使用
字符函数
介绍
字符函数是oracle中最常用的函数,我们来看看有哪些字符函数:
lower(char):将字符串转化为小写的格式。
upper(char):将字符串转化为大写的格式。
length(char):返回字符串的长度。
substr(char,m,n):取字符串的子串      n代表取n个的意思,不是代表取到第n个
replace(char1,search_string,replace_string)
instr(char1,char2,[,n[,m]])取子串在字符串的位置
问题:将所有员工的名字按小写的方式显示
SQL> select lower(ename) from emp;
问题:将所有员工的名字按大写的方式显示。
SQL> select upper(ename) from emp;
问题:显示正好为5个字符的员工的姓名。
SQL> select * from emp where length(ename)=;
问题:显示所有员工姓名的前三个字符。
SQL> select substr(ename,,) from emp;
问题:以首字母大写,后面小写的方式显示所有员工的姓名。
SQL> select upper(substr(ename,,)) || lower(substr(ename,,length(ename)-))  from emp;
问题:以首字母小写,后面大写的方式显示所有员工的姓名。
SQL> select lower(substr(ename,,)) || upper(substr(ename,,length(ename)-))  from emp;
问题:显示所有员工的姓名,用“我是老虎”替换所有“A”
SQL> select replace(ename,'A', '我是老虎') from emp;
数学函数 介绍
数学函数的输入参数和返回值的数据类型都是数字类型的。数学函数包括cos,cosh,exp,ln, log,sin,sinh,sqrt,tan,tanh,acos,asin,atan,round,我们讲最常用的:
round(n,[m]) 该函数用于执行四舍五入,如果省掉m,则四舍五入到整数,如果m是正数,则四舍五入到小数点的m位后。如果m是负数,则四舍五入到小数点的m位前。
trunc(n,[m]) 该函数用于截取数字。如果省掉m,就截去小数部分,如果m是正数就截取到小数点的m位后,如果m是负数,则截取到小数点的前m位。
mod(m,n)
floor(n) 返回小于或是等于n的最大整数
ceil(n) 返回大于或是等于n的最小整数
对数字的处理,在财务系统或银行系统中用的最多,不同的处理方法,对财务报表有不同的结果。 问题:显示在一个月为30天的情况下,所有员工的日薪金,忽略余数。
SQL> select trunc(sal/), ename from emp;
or
SQL> select floor(sal/), ename from emp; 在做oracle测试的时候,可以使用dual表
select mod(,) from dual;结果是0
select mod(,) from dual;结果是1 其它的数学函数,有兴趣的同学可以自己去看看:
abs(n): 返回数字n的绝对值
select abs(-) from dual;
acos(n): 返回数字的反余弦值
asin(n): 返回数字的反正弦值
atan(n): 返回数字的反正切值
cos(n):
exp(n): 返回e的n次幂
log(m,n): 返回对数值
power(m,n):    返回m的n次幂
日期函数
介绍
日期函数用于处理date类型的数据。
默认情况下日期格式是dd-mon-yy 即12-7月-
()sysdate: 该函数返回系统时间 (年月日)
()add_months(d,n) 加月份
()last_day(d):返回指定日期所在月份的最后一天
问题:查找已经入职8个月多的员工
SQL> select * from emp where sysdate>=add_months(hiredate,);
问题:显示满10年服务年限的员工的姓名和受雇日期。
SQL> select ename, hiredate from emp where sysdate>=add_months(hiredate,*);
问题:对于每个员工,显示其加入公司的天数。
SQL> select floor(sysdate-hiredate) "入职天数",ename from emp;
or
SQL> select trunc(sysdate-hiredate) "入职天数",ename from emp;
问题:找出各月倒数第3天受雇的所有员工。
SQL> select hiredate,ename from emp where last_day(hiredate)-=hiredate;

oracle5的更多相关文章

  1. [ERROR][org.springframework.web.context.ContextLoader][main] Context initialization failed org.sprin

    做一个SSH为基础框架的webapp小DEMO,复制了一把以前可以跑的代码,竟发现无法初始化数据源,报错如下: [ERROR][org.springframework.web.context.Cont ...

  2. Orcale语句大全

    原文地址:http://www.cnblogs.com/omygod/archive/2007/08/31/876620.html Oracle 语句大全 1. Oracle安装完成后的初始口令?  ...

  3. 浅谈数据库技术,磁盘冗余阵列,IP分配,ECC内存,ADO,DAO,JDBC

    整理-----数据库技术,磁盘冗余阵列,IP分配, ECC内存,ADO, DAO,JDBC 1.MySQL MySQL是最受欢迎的开源SQL数据库管理系统,它由 MySQL AB开发.发布和支持.My ...

  4. 数据库 --> 5种关系型数据库比较

    5种关系系数据库比较 目前,商品化的数据库管理系统以关系型数据库为主导产品,技术比较成熟.面向对象的数据库管理系统虽然技术先进,数据库易于开发.维护,但尚未有成熟的产品.国际国内的主导关系型数据库管理 ...

  5. sudo的使用和配置

    1 sudo是什么 Sudo是Unix/Linux平台上的一个非常有用的工具,它允许系统管理员分配给普通用户一些合理的“权利”,让他们执行一些只有超级用户或其他特许用户才能完成的任务,比如:运行一些像 ...

  6. Trove系列(五)—Trove的数据存储管理程序类型和版本管理功能介绍

    功能描述数据存储管理程序(Datastore)类型管理允许Trove的用户从操作者列出的名单中选择数据库存储管理程序和版本.操作者将可以控制数据库存储管理程序的类型,添加一个新的版本并去活一个老版本. ...

  7. Oracle常用傻瓜问题1000问

    Oracle常用傻瓜问题1000问 大家在应用ORACLE的时候可能会遇到很多看起来不难的问题, 特别对新手来说, 今天我简单把它总结一下, 发布给大家, 希望对大家有帮助! 和大家一起探讨, 共同进 ...

  8. Python与数据库[0] -> 数据库概述

    数据库概述 / Database Overview 1 关于SQL / About SQL 构化查询语言(Structured Query Language)简称SQL,是一种特殊目的的编程语言,是一 ...

  9. 怎么学好XXX

    怎么学好数据库是一个比较大题目,数据库不仅仅是写SQL那么简单,即使知道了SQL怎么写,还需要很清楚的知道这条SQL他大概扫描了多少数据,返回多少数据,是否需要创建索引.至于SQL优化是一个比较专业的 ...

随机推荐

  1. python多重继承:

    除了从一个父类继承外,Python允许从多个父类继承,称为多重继承. 多重继承的继承链就不是一棵树了,它像这样: class A(object): def __init__(self, a): pri ...

  2. bzoj 2482: [Spoj GSS2] Can you answer these queries II 线段树

    2482: [Spoj1557] Can you answer these queries II Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 145 ...

  3. sql server中创建链接服务器图解教程

    转自sql server中创建链接服务器图解教程 1.展开服务器对象-->链接服务器-->右击"新建链接服务器" 注意:必须以数据库管理员身份登录(通常也就是sa帐号) ...

  4. iOS开发网络篇—多线程断点下载

    iOS开发网络篇—多线程断点下载 说明:本文介绍多线程断点下载.项目中使用了苹果自带的类,实现了同时开启多条线程下载一个较大的文件.因为实现过程较为复杂,所以下面贴出完整的代码. 实现思路:下载开始, ...

  5. 如何备份MySql的数据库

    如何备份MySql的数据库 应该说一般的数据库都有BackUp的需求, MySql备份数据库的方式很简单, 但是在网上说得云里雾里, 也应该是我对MySql数据库不熟悉.   目标(Target) : ...

  6. React入门1

    React教程 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <t ...

  7. [C# 网络编程系列]专题六:UDP编程

    转自:http://www.cnblogs.com/zhili/archive/2012/09/01/2659167.html 引用: 前一个专题简单介绍了TCP编程的一些知识,UDP与TCP地位相当 ...

  8. [C# 网络编程系列]专题四:自定义Web浏览器

    转自:http://www.cnblogs.com/zhili/archive/2012/08/24/WebBrowser.html 前言: 前一个专题介绍了自定义的Web服务器,然而向Web服务器发 ...

  9. 机器更换登录密码重启,然后SQL Server登录不了

    解决方法:

  10. 图片上传,支持同步/异步、预览(MVC、uploadify异步提交、js预览、ajaxSubmit异步提交)兼容大部分浏览器,含代码

    图片上传代码,支持同步/异步和图片的预览 主要用了两种方式,可兼容大部分浏览器. 第一种使用uploadify异步上传,上传后返回图片路径显示到页面. 每二种使用ajaxSubmit异步上传,为兼容I ...