mysql 触发器 存储过程 java调用
触发器和存储过程是为了提高SQL的运行效率。
SQL语句先编译、后执行,而触发器与存储过程都会提前预编译完成,且只编译一次,供反复调用。
随着时代的进步,硬件与带宽的提升,触发器和存储过程提升效率并不明显,所以在传统或并发量低的项目中已经很少用到了。
1.触发器
简单的作用示意:用于增删改的时候,表关联的连贯操作(具体根据需求的表设计定义)。以前会有人说可以用来做日志统计,现实开发中,其实很少有人用库表做日志。
创建:
CREATE TRIGGER trigger_name trigger_time trigger_event ON tb_name FOR EACH ROW exesql
注释:
trigger_name 触发器名称
trigger_time 触发时间,值:BEFORE、AFTER
trigger_event 触发事件,值:INSERT、DELETE、UPDATE
tb_name 表名称,触发器建立在哪个表的基础上
exesql 触发器条件满足时,执行的sql或函数
列子:
DELIMITER $$
drop trigger if exists ms.trigger_test;
create trigger ms.trigger_test after insert
on ms.master for each row
begin
INSERT INTO slave (s_id, s_content) VALUES (new.m_id,new.m_content);
end
$$
注:
DELIMITER $$ 定义结束符$$,意味SQL语句以$$结束,mysql默认;分号结束。
new表示记录更新后的值,更新前的值用old
该脚本不可以在视图工具Navicat或dbvisual里执行。
必须如图执行

2.存储过程
简单描述:存储过程是一个特定的SQL语句集,在数据库中只需编译一次,重复使用。一般项目不建议使用存储过程,维护麻烦。
优点:重复使用、减少网络流量、防止SQL注入(关键)
缺点:应用层程序员调试麻烦、可移植性低、可扩展性差
CREATE PROCEDURE PROCEDURE_NAME (PROCEDURE_MODE PARAM_NAME PARAM_TYPE) EXE_SQL
注释:
PROCEDURE_NAME 存储过程名字
PROCEDURE_MODE 存储过程类型,有IN、OUT、INOUT
PARAM_NAME 参数引用名称
PARAM_TYPE 参数类型(int、varchar、datetime等等)
EXE_SQL 执行sql语句
IN例子:
DELIMITER $$
DROP PROCEDURE IF EXISTS ms.in_procedure;
CREATE PROCEDURE ms.in_procedure(IN param int)
BEGIN
SELECT param;
SET param=3;
SELECT param;
END
$$ SET @param=1;
CALL ms.in_procedure(@param);
SELECT @param;
$$
注:
DELIMITER $$ 定义结束符$$,意味SQL语句以$$结束,mysql默认;分号结束。
该脚本不可以在视图工具Navicat或dbvisual里执行。
必须如图执行

OUT例子:
DELIMITER $$
DROP PROCEDURE IF EXISTS ms.out_procedure;
CREATE PROCEDURE ms.out_procedure(OUT param int)
BEGIN
SELECT param;
SET param=3;
SELECT param;
END
$$ SET @param=1;
CALL ms.out_procedure(@param);
SELECT @param;
$$
注:
DELIMITER $$ 定义结束符$$,意味SQL语句以$$结束,mysql默认;分号结束。
该脚本不可以在视图工具Navicat或dbvisual里执行。
必须如图执行

INOUT例子
DELIMITER $$
DROP PROCEDURE IF EXISTS ms.inout_procedure;
CREATE PROCEDURE ms.inout_procedure(INOUT param int)
BEGIN
SELECT param;
SET param=3;
SELECT param;
END
$$ SET @param=1;
CALL ms.inout_procedure(@param);
SELECT @param;
$$
注:
DELIMITER $$ 定义结束符$$,意味SQL语句以$$结束,mysql默认;分号结束。
该脚本不可以在视图工具Navicat或dbvisual里执行。
必须如图执行

3.java调用存储过程
package com.nginx.session.test; import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.SQLException; import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.CallableStatementCallback;
import org.springframework.jdbc.core.CallableStatementCreator;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.test.context.junit4.SpringRunner; @RunWith(SpringRunner.class)
@SpringBootTest
public class JDBCTest {
@Autowired
private JdbcTemplate jdbcTemplate; @Test
public void test(){
Integer value = jdbcTemplate.execute(new CallableStatementCreator() {
@Override
public CallableStatement createCallableStatement(Connection con) throws SQLException {
String storedProc = "{call ms.inout_procedure (?)}";
CallableStatement cs = con.prepareCall(storedProc);
cs.setInt(1,1);
return cs;
}
}, new CallableStatementCallback<Integer>() {
@Override
public Integer doInCallableStatement(CallableStatement cs) throws SQLException {
cs.execute();
return cs.getInt(1);
}
});
System.out.println(value);
}
}
mysql 触发器 存储过程 java调用的更多相关文章
- JDBC对MySQL数据库存储过程的调用
一.MySQL数据库存储过程: 1.什么是存储过程 存储过程(英文:Stored Procedure)是在大型数据库系统中,为了完成特定功能而编写的一组的SQL语句集.存储过程经编译存储在数据库中,用 ...
- mysql创建存储过程及调用
创建存储过程简单示例: DELIMITER //CREATE PROCEDURE ccgc()BEGINSELECT * FROM TEXT;SELECT * FROM s_user;END//DEL ...
- Oracle存储过程java 调用
1.nest表组合成结果集,然后以游标变量的形式返回 --创建类型 create or replace package mytest is -- Author : ADMINISTRATOR -- ...
- Java调用MySQL存储过程
Java调用MySQL的存储过程,需要用JDBC连接,环境eclipse 首先查看MySQL中的数据库的存储过程,接着编写代码调用 mysql> show procedure status; + ...
- Mysql 视图 游标 触发器 存储过程 事务
Mysql 视图 触发器 存储过程 游标 游标是从数据表中提取出来的数据,以临时表的形式存放在内存中,在游标中有一个数据指针,在初始状态下指向的是首记录,利用fetch语句可以移动该指针,从而对游标中 ...
- iBatis调用存储过程以及MySQL创建存储过程
首先是MySQL中创建存储过程的SQL -- 列出全部的存储过程 SHOW PROCEDURE STATUS; -- 查看一个已存在的存储过程的创建语句,假设此存储过程不存在,会提示SQL错误(130 ...
- MySQL笔记 存储过程 游标 触发器
第二十三章 使用存储过程 MySQL5 中添加了存储过程的支持. 大多数SQL语句都是针对一个或多个表的单条语句.并非所有的操作都怎么简单.经常会有一个完整的操作需要多条才能完成 存储过程简单来说,就 ...
- 关于mysql触发器和存储过程的理解
内容源自:一篇很棒的 MySQL 触发器学习教程 一.触发器概念 触发器(trigger):监视某种情况,并触发某种操作,它是提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊 ...
- Mysql存储过程及调用
存储过程: 存储过程是SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理.存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量.有条件执行以及其它强大的 ...
随机推荐
- FreeBSD这就是你的速度???
想一心一意的用一款UNIX操作系统,真不容易,FreeBSD你为啥这么坑? 用pkg安装软件,国内没有相应的源,只好从官网上下,欲哭无泪!有点怀恋CentOS的yum了,163的源,那速度杠杠滴! 先 ...
- 【转】 在Eclipse中使用JUnit4进行单元测试(中级篇)
http://blog.csdn.net/andycpp/article/details/1327346 我们继续对初级篇中的例子进行分析.初级篇中我们使用Eclipse自动生成了一个测试框架,在这篇 ...
- java.lang.IllegalArgumentException: column '_id' does not exist问题的解决方案
我在使用SimpleCursorAdapter的过程中遇到了问题: java.lang.IllegalArgumentException: column '_id' does not exist 这个 ...
- HTTP 请求:GET vs. POST
两种在客户端和服务器端进行请求-响应的常用方法是:GET 和 POST. GET - 从指定的资源请求数据 POST - 向指定的资源提交要处理的数据 GET 基本上用于从服务器获得(取回)数据.注释 ...
- 没有Promise的时候自己处理复合异步请求
function getList(options){ $.ajax(success:funciton(){ if(options.callback) options.callback.call(); ...
- asp.net中TextBox只能输入数字的最简洁的两种方法
如下TextBox <asp:textboxonkeypress="isnum()"id="TextBox1"runat="server&quo ...
- poj 2513(欧拉路径+字典树映射)
题目链接:http://poj.org/problem?id=2513 思路:题目还是很简单的,就是判断是否存在欧拉路径,我们给每个单词的头和尾映射序号,统计度数.对于给定的无向图,当且仅当图连通并且 ...
- iOS - url中文和特殊字符转码###
- (NSString *)generateUrl:(NSString *)url{ /** 第一个参数:NULL 第二个参数:C语言的字符串 第三个参数:NULL 第四个参数:要转义的字符串,不要乱 ...
- day17 内置函数
一.内置函数接下来,我们就一起来看看python里的内置函数 分类图 1.作用域函数 基于字典的形式获取局部变量和全局变量 globals()——获取全局变量的字典 locals()——获取执行本方法 ...
- 【Python】Python获取命令行參数
有时候须要用同一个Python程序在不同的时间来处理不同的文件,此时假设老是要到Python程序中去改动输入.输出文件名称.就太麻烦了. 而通过Python获取命令行參数就方便多了.以下是我写得一个小 ...