1 如何锁一个表的某一行 2 锁定数据库的一个表 加锁语句: 加锁后其它人不可操作,直到加锁用户解锁,用commit或rollback解锁 。几个例子帮助大家加深印象 1)排它锁 新建两个连接 在第一个连接中执行以下语句 在第二个连接中执行以下语句 若同时执行上述两个语句,则select查询必须等待 ...
分类:
数据库 时间:
2016-08-31 11:55:49
阅读次数:
185
11G中有个新特性,当表无数据时,不分配segment,以节省空间 解决方法: 1、insert一行,再rollback就产生segment了。 该方法是在在空表中插入数据,再删除,则产生segment。导出时则可导出空表。 2、设置deferred_segment_creation 参数 show ...
分类:
数据库 时间:
2016-08-26 22:39:09
阅读次数:
155
事务:保障流程的完整执行保证程序某些程序在运行时同时成功同时失败,保证程序的安全性 begin tran --在流程开始的位置加 --此处写SQL语句 if @@error>0 --ERRORSQL自带的错误提示 begin rollback tran --回滚事务,到begin tran 的位置, ...
分类:
数据库 时间:
2016-08-22 09:27:27
阅读次数:
210
因为DDL没有事务性,所以DDL不能回滚。 要实现自动回滚。(begin,commit,rollback),则SQL语句中只能包括DML。 这样,自动化发布就会受限规范格式。 故而,一刀切的办法是,假定所有SQL不支持事务,自已定义好ROLLBACK的SQL脚本,在出错时能用代码回滚, 而不是依赖于 ...
分类:
数据库 时间:
2016-08-19 13:16:53
阅读次数:
214
触发器无需commit也不能写commit触发器和触发它的DML是同一个事务DML提交了,触发器的操作也提交了,要不就一起回滚了当然,如果你一定要在触发器里写COMMIT那就用自治事务相当于一个事务里的子事务 正常情况下,Oracle规定在触发器中不能运行 ddl语句和commit,rollback ...
分类:
数据库 时间:
2016-08-18 01:06:37
阅读次数:
315
主要是使用connection的三个方法实现: 开始事物:取消默认提交:connection.setAutoCommit(false);//其可选择false和true 都成功提交事物:connection.commit(); 回滚事物:connection.rollback(); package ...
分类:
数据库 时间:
2016-08-15 17:25:45
阅读次数:
212
事物(transaction) -->作为单个逻辑工作单元执行的一系列操作(要么全部成功要么全部失败) 提交(commit) -->系列操作全部成功的场合才会执行 回滚(rollback) -->系列操作其中有一条失败的时候就执行rollback ...
分类:
数据库 时间:
2016-08-10 20:49:08
阅读次数:
195
数据库的事务处理可以保证一组处理结果的正确性。mysql中只有INNODB和BDB引擎的数据表才支持事务处理,对于不支持事务的MyISAM引擎数据库可以使用表锁定的方法来实现相同的功能。mysql的事务处理主要有两种方法来实现。1、用begin,rollback,commit来实现。begin开始一个事务r..
分类:
数据库 时间:
2016-08-10 01:04:40
阅读次数:
152
1.关于“因为数据库正在使用,所以无法获得对数据库的独占访问权”的最终解决方案 关键SQL语句: ALTER DATABASE [datebase] SET OFFLINE WITH ROLLBACK IMMEDIATE 用完之后再 alter database [dbname] set onlin ...
分类:
数据库 时间:
2016-08-09 18:39:23
阅读次数:
140
事务:保障流程的完整执行保证程序某些程序在运行时同时成功同时失败,保证程序的安全性 begin tran --在流程开始的位置加 --此处写SQL语句 if @@error>0 --ERRORSQL自带的错误提示begin rollback tran --回滚事务,到begin tran 的位置,就 ...
分类:
数据库 时间:
2016-08-07 15:30:48
阅读次数:
359