1、MySQL存储过程

  1.1、什么是存储过程

带有逻辑的sql语句;带有流程控制语句(if  while)等等 的sql语句

  1.2、存储过程的特点

1)执行效率非常快,存储过程是数据库的服务器端执行的。
      2)移植性很差,不同数据库的存储过程是不能移植的。

2、存储过程的语法

-- 创建存储过程
1 DELIMITER $  -- 声明存储过程的结束符
CREATE PROCEDURE pro_test() -- 创建存储过程 存储过程的名称(参数列表)
BEGIN  -- 开始
    -- 这中间可以写多个sql语句     -- sql语句+流程控制等
 
END $ -- 结束 结束符
 --执行存储过程
CALL pro_test(); -- call存储过程的名称(参数)
 -- 存储过程名称里面的参数:
IN :表示输入参数,可以携带数据存储过程中
OUT:表示输出参数,可以从存储过程中返回结果
INOUT:表示输入输出参数,既可以输入功能,也可输出功能
-- 删除存储过程
DROP PROCEDURE pro_test; -- 删除存储过程 存储过程的名称;

3、实例演示

  3.1、带有参数的存储过程           Java代码调用存储过程的方法:https://www.cnblogs.com/dshore123/p/10582283.html

 -- 需求:传入一个员工的id,查询员工的信息
DELIMITER $
CREATE PROCEDURE pro_findById(IN eid INT) -- IN: 输入参数; eid:传入参数的名称; int:传入参数的类型
BEGIN
SELECT * FROM employee WHERE id = eid;
END $ -- 调用
CALL pro_findByID(4)

调用pro_findByID() 后的结果图

         

  3.2、带有输出参数的存储过程

 -- 带有输出参数的存储过程
DELIMITER $
CREATE PROCEDURE pro_test_out(OUT str VARCHAR(20)) -- out:输出参数
BEGIN
-- 给参数赋值
SET str = 'helloMySQL';
END $ CALL pro_test_out(@NAME); -- 调用pro_test_out存储过程
SELECT @NAME; -- 查询pro_test_out存储过程 -- 如何返回接收的返回数值
-- ****mysql的变量******
-- 全局变量(内置变量):mysql数据库中内置的变量(所有连接都起作用)
-- 查看所有的全局变量:show variables;
-- 查看某个全局变量:select @@变量名
-- 修改全局变量:set 变量名 = 新值 -- 会话变量:只存在于当前客户端与数据库的一次连接当中;如果断开,那么会话变量将全部失效(丢失)。
-- 定义会话变量: set @变量 = 值;
-- 查看会话变量: select @变量;
-- character_set_client: 服务器的接收编码
-- character_set_results: 服务器的输出编码 -- 局部变量:在存储过程中使用的变量就叫局部变量;只要存储过程执行完毕,局部变量就丢失。

结果图

  3.3、带有输入输出参数的存储过程

 -- 带有输入输出参数的存储过程
DELIMITER $
CREATE PROCEDURE pro_test_InOut(INOUT n INT) -- INOUT: 输入输出参数
BEGIN
-- 查看变量
SELECT n;
SET n=500;
END $ -- 调用
SET @n=10;
CALL pro_test_InOut(@n);
SELECT @n;

结果图

         

  3.4、带有条件判断存储过程

 -- 需求:输入一个整数,如果是1,则返回'星期一';如果是2,则返回'星期二';如果是3,则返回'星期三'。如果是其他,则返回'输入有误'
DELIMITER $
CREATE PROCEDURE pro_testIf(IN num INT,OUT str VARCHAR(32))
BEGIN
IF num=1 THEN
SET str = '星期一';
ELSEIF num = 2 THEN
SET str = '星期二';
ELSEIF num = 3 THEN
SET str = '星期三';
ELSE
SET str = '输入错误';
END IF;
END $ CALL pro_testIf(3,@str);
SELECT @str;

结果图

  3.5、带有循环功能的存储过程

 -- 需求:输入一个整数,求和。例如:输入100 ,统计1~100的和
DELIMITER $
CREATE PROCEDURE pro_testWhile(IN num INT,OUT result INT)
BEGIN
-- 定义一个局部变量 for(int i=1;i<=100;i++)
DECLARE i INT DEFAULT 1; -- 定义一个局部变量i,int类型,默认值为1。
DECLARE vsum INT DEFAULT 0; -- 定义一个局部变量vsum,int类型,默认值为0。
WHILE i <= num DO
SET vsum = vsum + i;
SET i = i + 1;
END WHILE;
SET result = vsum;
END $ CALL pro_testWhile(100,@result);
SELECT @result;

结果图

原创作者:DSHORE

作者主页:http://www.cnblogs.com/dshore123/

原文出自:https://www.cnblogs.com/dshore123/p/10559182.html

欢迎转载,转载务必说明出处。(如果本文对您有帮助,可以点击一下右下角的 推荐,或评论,谢谢!

Java基础89 MySQL存储过程的更多相关文章

  1. Java基础86 MySQL数据库基础知识

    本文知识点(目录): 1.MySQL数据库的概述    2.MySQL数据库的管理[对数据库的操作](查询.删除.创建数据库,以及查询和修改数据库的编码模式)    3.表的管理[对数据库 表的操作] ...

  2. java, mybatis, 调用mysql存储过程

    Map<String, Object> bindinfo = new HashMap<String, Object>();            bindinfo.put(&q ...

  3. Java基础87 MySQL数据约束

    1.默认值 -- 创建表student1,设置address字段有默认值 create table student1 ( id int, name ), address ) default '广东省深 ...

  4. Java基础之MySQL数据库与JDBC

    一.数据库 DBMS         数据库管理系统 是由多个程序构成的专门用来管理大量数据的计算机系统 Server       提供数据存储.检索.计算等服务的网络程序+系统服务 Notifier ...

  5. Java基础92 MySQL插入当前系统时间

    1.时间格式 用yyyy表示年份(year). -- y  表示年的最后一位,yy 表示年的最后2位,yyy 表示年的最后3位,yyyy 用4位数表示年用MM表示月份(month).-- mm 用2位 ...

  6. Java基础91 mysql的用户权限设置问题

    1.概述 1)MySQL数据库中root用户具有最高的权限(超级用户),可以对任何数据库,任何表进行操作. 2)权限账户,只拥有部分权限(CRUD) .例如:只能操作某个数据库的某张表等等. 2.my ...

  7. Java基础90 MySQL触发器

    1.创建触发器 CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name FOR EACH ROW trigger_stmt ...

  8. ava基础MySQL存储过程 Java基础 JDBC连接MySQL数据库

    1.MySQL存储过程   1.1.什么是存储过程 带有逻辑的sql语句:带有流程控制语句(if  while)等等 的sql语句   1.2.存储过程的特点 1)执行效率非常快,存储过程是数据库的服 ...

  9. 面试官突然问我MySQL存储过程,我竟然连基础都不会!(详细)

    所有知识体系文章,GitHub已收录,欢迎Star!再次感谢,愿你早日进入大厂! GitHub地址: https://github.com/Ziphtracks/JavaLearningmanual ...

随机推荐

  1. docker cp 和docker exec 查看docker 运行的容器信息

    1. 使用docker 运行 redis 和 postgresql docker run -d -p : -v /redis/data/:/data redis docker run -d -p : ...

  2. 【转】mysql优化步骤

    作者:zhuqz链接:https://www.zhihu.com/question/19719997/answer/81930332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请 ...

  3. AtCoder Grand Contest 006

    AtCoder Grand Contest 006 吐槽 这套题要改个名字,叫神仙结论题大赛 A - Prefix and Suffix 翻译 给定两个串,求满足前缀是\(S\),后缀是\(T\),并 ...

  4. 洛谷 P1073 最优贸易 解题报告

    P1073 最优贸易 题目描述 \(C\)国有\(n\)个大城市和\(m\)条道路,每条道路连接这\(n\)个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这\(m\)条道路中有一部分 ...

  5. 40+ 个非常有用的 Oracle 查询语句

    40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询.这些是所有 Oracle 开发者都必备的技能,所以快快收藏吧! 日期/时间 ...

  6. IntelliJ IDEA 创建Java Web项目

    1. 创建Web项目 可以先阅读 IntelliJ IDEA 的安装和使用教程 注意:IntelliJ IDEA 中 Project 和 Module 的概念及区别 创建完成后点击Import Cha ...

  7. 使用IntelliJ IDEA工具创建SSM(Spring+MyBatis)项目

    1. 安装和使用IntelliJ IDEA 参考:IntelliJ IDEA 的安装和使用教程 2. 创建Web项目 参考:IntelliJ IDEA 创建Java Web项目 3. Spring整合 ...

  8. 解题:POI2008 Building blocks

    题面 显然我们需要考虑每一个区间,而这个问题显然我们都会做,这不就是这道题么,也就是说假如中位数是$mid$,区间和是$sum$,那么代价就是$\sum\limits_{i=l}^r |mid-num ...

  9. bzoj 4328 始祖鸟

    4328: JSOI2012 始祖鸟 Time Limit: 10 Sec  Memory Limit: 256 MBSec  Special JudgeSubmit: 76  Solved: 52[ ...

  10. ubuntu,centor 安装apache bench

    ab全称为:apache bench. 是apache自带的压力测试工具.ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试.比如nginx.to ...