第五天,存储过程,查询区分大小,事务处理(回滚,提交)

※存储过程
存储过程是保存在数据库上的一段可执行代码。
1、定义存储过程的语法是:
Create procedure sp_name (参数..)
Begin
SQL语句
End;
2、调用它的方法:
Call sp_name(参数…); //空参时则括号中不填内容

3、演示
1)不带参数
定义(delimiter用于定义结束符):
DELIMITER $$
CREATE PROCEDURE p1()
BEGIN
INSERT INTO person2 VALUES(‘P05‘,‘李四‘,0);
SELECT * FROM person2;
END$$
DELIMITER ;
调用:
call p1();

2)带输入参数
DELIMITER $$
CREATE PROCEDURE p2(in id varchar(32), in nm varchar(30) )
BEGIN
INSERT INTO person2 VALUES(id,nm,0);
SELECT * FROM person2;
END$$
DELIMITER ;

call p2(‘P06‘,‘张飞‘);
CALL p2(‘P07‘,‘刘备‘);

3) 带输入、输出参数
定义:
DELIMITER $$
CREATE PROCEDURE p3(in id varchar(32), in nm varchar(30), out num int )
BEGIN
INSERT INTO person2 VALUES(id,nm,0);
SELECT count(*) into num FROM person2;
END$$
DELIMITER ;

调用:
CALL p3(‘P08‘,‘关羽‘,@aa); //一个@为用户变量,两个@为系统变量
输出返回值(输出参数)
SELECT @aa;

//输出系统变量“@@version”的值
SELECT @@VERSION

※查询内容区分大小写
mysql查询默认是不区分大小写的 如:
select * from table_name where a like ‘a%‘   
select * from table_name where a like ‘A%‘   
select * from table_name where a like ‘a%‘
select * from table_name where a like ‘A%‘
效果是一样的。
要让mysql查询区分大小写,可以:
select * from table_name where binary a like ‘a%‘  
select * from table_name where binary a like ‘A%‘   
select * from table_name where binary a like ‘a%‘
select * from table_name where binary a like ‘A%‘
也可以在建表时,加以标识 
create table table_name(
a varchar(20) binary
);

※事务: 一个事务只会有一个结果,要么成功,要么失败。
举例:
P09,‘赵子龙‘ 一次买了两辆车,需要把赵子龙的信息存储到person2表,同时还要把两辆车的信息存储到car表-----两个表的存储动作就是一个事务,要么成功(两个表的信息都成功存储), 要么失败(只要其中一个表的一条数据存储失败,其它表的信息都不能存储进去,如果存进去则要还原)。
类似的例子,还有:银行转账! 销售单和销售明细!

SQL演示:
START TRANSACTION; //开启事务
DELETE FROM person2 WHERE id=‘P04‘;
DELETE FROM person2 WHERE id=‘P05‘;
ROLLBACK/COMMIT; //回滚/提交

START TRANSACTION; //开启事务
INSERT INTO person2 VALUES(‘P09‘,‘赵子龙‘,‘1‘);
INSERT INTO car VALUES(‘C007‘,‘BMW‘,50,‘P09‘);
INSERT INTO car VALUES(‘C008‘,‘QQ‘,7,‘P09‘);
ROLLBACK/COMMIT; //回滚/提交

DELETE FROM car WHERE id=‘C007‘;
DELETE FROM car WHERE id=‘C008‘;
DELETE FROM person2 WHERE id=‘P09‘;

※事务的隔离

时间: 2024-10-12 23:58:33

第五天,存储过程,查询区分大小,事务处理(回滚,提交)的相关文章

事务处理-回滚(转账操作)

JDBC事务处理-四大原则 原子性一致性隔离性持久性 第一步:实现转账操作 假设在账户中,盖伦有余额5000元,赵信有余额2000元, 盖伦要向赵信转账1000元. public static void outMoney(Connection conn,String name,int account) throws SQLException{ String sql="update t_account set balance=balance-? where name=?"; Prepar

查询oracle 数据库中回滚段中一个时间点被修改的表数据并还原表中原来数据

利用下面的SQL就可以查处最近更改的数据. SQL> SELECT ID,NAME,VERSIONS_STARTTIME,VERSIONS_ENDTIME,VERSIONS_OPERATION FROM TEST VERSIONS BETWEEN TIMESTAMP MINVALUE AND MAXVALUE WHERE VERSIONS_STARTTIME IS NOT NULL ORDER BY VERSIONS_STARTTIME DESC; 通过以上小实验可以看出,VERSIONS_ST

mysql查询区分大小

查询时加上binary关键词就能在查询时区分字符大小如下: mysql> select name from pe where binary name='Claws';+-------+| name  |+-------+| Claws |+-------+mysql> select name from pe where binary name='claws';Empty set (0.00 sec)like条件的使用: mysql> select name from pe where n

SQL总结(五)存储过程

SQL总结(五)存储过程 概念 存储过程(Stored Procedure):已预编译为一个可执行过程的一个或多个SQL语句. 创建存储过程语法 CREATE proc | procedure procedure_name [{@参数数据类型} [=默认值] [output], {@参数数据类型} [=默认值] [output], .... ] as SQL_statementsgo 存储过程与SQL语句对比 优势: 1.提高性能SQL语句在创建过程时进行分析和编译. 存储过程是预编译的,在首次

[Beego模型] 五、构造查询

[Beego模型] 一.ORM 使用方法 [Beego模型] 二.CRUD 操作 [Beego模型] 三.高级查询 [Beego模型] 四.使用SQL语句进行查询 [Beego模型] 五.构造查询 [Beego模型] 六.事务处理 QueryBuilder 提供了一个简便,流畅的 SQL 查询构造器.在不影响代码可读性的前提下用来快速的建立 SQL 语句. QueryBuilder 在功能上与 ORM 重合, 但是各有利弊.ORM 更适用于简单的 CRUD 操作,而 QueryBuilder 则

MyBatis系列教程(五)-- 处理存储过程(Handle the Store Procedure)

所需要用到的其他工具或技术: 项目管理工具 : Maven 测试运行工具 : Junit 数据库 : Derby 本节需要用到的有2部分,第一部分是如何在Derby中创建存储过程,第二部分是如何在Mybatis中调用存储过程 一. 在Derby中创建存储过程 1.在Eclipse中创建一个新的普通java项目命名为Test_Store_Procedure 2.在com.freud.practice包下创建一个Class命名为StoreProcedureOperationClass.class p

SubSonic3.0使用存储过程查询时,不能使用output参数返回值的问题修改

有个群友问SubSonic3.0执行存储过程时能不能使用output参数返回值,说测试过后获取不到返回值,早上有些时间所以就尝试修改了一下 首先在数据库中创建一个存储过程 1 CREATE PROCEDURE [OutValue] 2 @a int, 3 @b int, 4 @c int output 5 AS 6 Set @c = @a + @b 7 GO 打开Settings.ttinclude模板,找到SPParam类,修改为下面代码 1 public class SPParam{ 2 p

mysql查询数据库大小和表

每个mysql都有一个库information_schema,里面有一张表TABLES存储了所有数据库表的信息,因此,可以从这张表中查看数据库大小和表大小 查询数据库大小 select concat(round((sum(data_length)+sum(index_length))/1024/1024/1024,2),'GB') as data from information_schema.tables where table_schema='esb'; 查询数据库中表大小 select c

oracle入门(8)——实战:支持可变参数、多种条件、多个参数排序、分页的存储过程查询组件

[本文介绍] 学了好几天,由于项目需要,忙活了两天,写出了个小组件,不过现在还只能支持单表操作.也没考虑算法上的优化,查询速度要比hibernate只快了一点点,可能是不涉及多表查询的缘故吧,多表的情况下才更快. 经非专业的测试,在有分页的情况下,在300万条数据里面查询的时间保持在0.1秒内.相同查询条件+分页的情况下,hibernate 用时0.3秒内. 不分页的条件下,查出来的数据越多,时间越长,时间长的话,跟hibernate相相比就没什么优势了. [思路] 我的思路是从java传来”字