-- 存储过程示例一   in
DROP DATABASE IF EXISTS tdemo;
CREATE DATABASE tdemo CHARACTER SET=utf8;
 
USE tdemo;
CREATE TABLE temp2(
   id INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
   nodename VARCHAR(10)
)ENGINE=INNODB DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci;
 
 
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo1 $$
CREATE PROCEDURE pro_demo1(IN tid INT)
BEGIN
   SELECT tid; 
   SELECT * FROM temp2 WHERE id=tid;
END $$
 
CALL pro_demo1(1);
 
-- 存储过程示例 out
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo2 $$
CREATE PROCEDURE pro_demo2(OUT tnodename VARCHAR(10))
BEGIN
   DECLARE tname VARCHAR(10);
   SET tname = 'tl';
   SELECT nodename INTO tnodename FROM temp2 WHERE id=1;
   SELECT tnodename;
   SET tnodename=CONCAT(tname,tnodename);
   SELECT tname;
   SELECT tnodename;
END $$
 
CALL pro_demo2(@name);
SELECT @name;
 
-- 存储过程示例 in+out
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo3 $$
CREATE PROCEDURE pro_demo3(IN tid INT,OUT tnodename VARCHAR(10))
BEGIN
    DECLARE tname VARCHAR(10) DEFAULT 'tl';
    SELECT nodename INTO tnodename FROM temp2 WHERE id=tid;
    SET tnodename = CONCAT(tname,tnodename);
    SELECT tnodename;
    SET tname = 'll';
    SET tnodename = CONCAT(tname,tnodename);
END $$
 
CALL pro_demo3(1,@name);
SELECT @name;
 
-- 存储过程示例 inout
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo4 $$
CREATE PROCEDURE pro_demo4(INOUT temp VARCHAR(10))
BEGIN
   DECLARE tname VARCHAR(10) DEFAULT 'tlll';
   SELECT nodename INTO temp FROM temp2 WHERE id=CAST(temp AS SIGNED);
   SELECT temp;
   SET temp = CONCAT(tname,temp);
END $$
 
SET @temp=1;
CALL pro_demo4(@temp);
SELECT @temp;
 
 
-- 存储过程判断语句 if case
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo5 $$
CREATE PROCEDURE pro_demo5(IN tstr VARCHAR(10),IN tid INT)
BEGIN
   DECLARE temp VARCHAR(100);
   IF tid > 0 THEN
      SELECT 'tid > 0 ';
   ELSEIF tid = 0 THEN
      SELECT 'tid = 0 ';
   ELSEIF tid IS NULL THEN
      SELECT 'tid is null';
   ELSE
      SELECT 'tid < 0';
   END IF;
   CASE WHEN tstr ='tl' THEN
      SET temp = 'tstr = tl';
      SELECT temp;
   WHEN tstr IS NOT NULL THEN
      SET temp = 'tstr is not null';
      SELECT temp;
   ELSE
      SET temp = 'tstr is null';
      SELECT temp;
   END CASE;
END $$
 
CALL pro_demo5('a',2);
CALL pro_demo5('tl',0);
CALL pro_demo5(NULL,-1);
CALL pro_demo5(NULL,NULL);
 
 
-- 存储过程判断 条件 case if 嵌套
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo6 $$
CREATE PROCEDURE pro_demo6(IN str VARCHAR(10),IN id INT)
BEGIN
  DECLARE temp VARCHAR(100);
  CASE WHEN id>0 THEN
      SELECT 'id > 0';
      IF str IS NOT NULL THEN
         SET temp = 'str is not null';
         SELECT temp;
      ELSE
         SET temp = 'str is error';
         SELECT temp;
      END IF;
  WHEN id<0 THEN
      SELECT 'id < 0';
  WHEN id IS NULL THEN
      SELECT 'id is null';
  ELSE
      SELECT 'id is error';
  END CASE;
END $$
 
 
CALL pro_demo6('a',2);
CALL pro_demo6('tl',0);
CALL pro_demo6(NULL,-1);
CALL pro_demo6(NULL,NULL);
 
-- 存储过程 循环 while END WHILE
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo7 $$
CREATE PROCEDURE pro_demo7()
BEGIN
  DECLARE i INT;
  DECLARE str VARCHAR(10) DEFAULT '$';
  SET i = 0;
  WHILE i<5 DO
    SET str= CONCAT(str,',',CAST(i AS CHAR));
    INSERT INTO temp2(id,nodename) VALUES(25+i,str);
    SET i=i+1;
  END WHILE;
  SELECT str;
END $$
 
CALL pro_demo7();
 
-- 存储过程 循环 while repeat end repeat
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo8 $$
CREATE PROCEDURE pro_demo8()
BEGIN
   DECLARE i INT DEFAULT 0;
   DECLARE str VARCHAR(100) DEFAULT '$';
   REPEAT
     SET str= CONCAT(str,',',CAST(i AS CHAR));
     SET i = i+1;
   UNTIL i>=5
   END REPEAT;
   SELECT str;
END $$
 
CALL pro_demo8();
 
-- 存储过程 循环 loop end loop
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo9 $$
CREATE PROCEDURE pro_demo9()
BEGIN
     DECLARE i INT DEFAULT 0;
     DECLARE str VARCHAR(100) DEFAULT '$';
     loop_label:LOOP
        SET str = CONCAT(str,',',i);
        SET i = i+1;
     IF i>=5 THEN
     LEAVE loop_label;
     END IF;
     END LOOP;
     SELECT str;
END $$
 
CALL pro_demo9();
 
-- 存储过程 循环 loop end loop  iterate
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo10 $$
CREATE PROCEDURE pro_demo10()
BEGIN
     DECLARE i INT DEFAULT 0;
     DECLARE str VARCHAR(100) DEFAULT '$';
     loop_label:LOOP
     IF i=3 THEN
        SET i = i+1;
        ITERATE loop_label;  -- iterate 跳出当前循环
     END IF;
     SET str = CONCAT(str,',',i);   
     SET i = i+1;  
     IF i>=5 THEN
     LEAVE loop_label;
     END IF;
     END LOOP;
     SELECT str;
END $$
 
CALL pro_demo10();
 
-- 存储过程 游标
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo11 $$
CREATE PROCEDURE pro_demo11()
BEGIN
   DECLARE done INT;
   DECLARE id INT DEFAULT 0;
   DECLARE str VARCHAR(10) DEFAULT '';
   DECLARE cur_demo CURSOR FOR SELECT id,nodename FROM temp2 WHERE id=1; -- 声明一个游标变量
   DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1; -- 声明游标结束的标志位
   SET done = 0;
   OPEN cur_demo;  -- 打开游标
   loop_lable:LOOP
   IF done=1 THEN
     LEAVE loop_lable;
   END IF;
   FETCH cur_demo INTO id,str;
      INSERT INTO temp2 VALUES(100,'tltl');
   END LOOP loop_lable;
   CLOSE cur_demo; -- 关闭游标
   SELECT id;
   SELECT str;
END $$
 
CALL pro_demo11();
 
 
 
-- 存储过程 游标
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo12 $$
CREATE PROCEDURE pro_demo12()
BEGIN
   DECLARE done INT;
   DECLARE id INT DEFAULT 0;
   SET str2 VARCHAR(10);
   DECLARE str VARCHAR(10) DEFAULT '';
   DECLARE cur_demo CURSOR FOR SELECT id,nodename FROM temp2 WHERE id=1; -- 声明一个游标变量
   DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1; -- 声明游标结束的标志位
   SET done = 0;
   OPEN cur_demo;  -- 打开游标
   FETCH cur_demo INTO id,str;
      SET str2=str;
   CLOSE cur_demo; -- 关闭游标
   SELECT str2;
END $$
 
CALL pro_demo12();
 
-- 存储过程  游标 循环
DELIMITER $$
USE tdemo $$
DROP PROCEDURE IF EXISTS pro_demo13 $$
CREATE PROCEDURE pro_demo13()
BEGIN
   DECLARE done INT DEFAULT 0;
   DECLARE tid INT;
   DECLARE tnodename VARCHAR(10);
   DECLARE cur_demo CURSOR FOR SELECT * FROM temp2 WHERE id BETWEEN 1 AND 5;
   DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;
   CREATE TEMPORARY TABLE tl(
      id INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
      info VARCHAR(20) NOT NULL
   );
   OPEN cur_demo;
   loop_label:LOOP
   IF done=1 THEN
     LEAVE loop_label;
   END IF;
     FETCH cur_demo INTO tid,tnodename;
     INSERT INTO tl(info) VALUES(CONCAT(tnodename,CAST(tid AS CHAR)));
   END LOOP loop_label;
   CLOSE cur_demo;
   SELECT * FROM tl;
   DROP TABLE tl;  
END $$
 
CALL pro_demo13();

mysql存储过程--学习的更多相关文章

  1. MySQL存储过程学习笔记

    MySQL在5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣.MySQL 5.0终于开始支持存储过程了. MySQL的关键字大小写通用.该学习笔记对关键字使用大写:变量名,表名使用小写. ...

  2. MySql存储过程学习总结

    创建存储过程 1.格式   MySQL存储过程创建的格式:CREATE PROCEDURE 过程名 ([过程参数[,...]]),举个例子: CREATE PROCEDURE proc1 (OUT s ...

  3. mysql存储过程学习(一)

    转载 什么是存储过程,存储过程的作用及优点  mysql存储过程详细教程  mysql 使用存储过程批量插数据 一.存储过程介绍: 存储过程(Stored Procedure)是一组为了完成特定功能的 ...

  4. mysql存储过程学习

    一.存储过程的创建 语法: CREATE PROCEDURE sp_name (参数)合法的SQL语句 mysql> delimiter // mysql> CREATE PROCEDUR ...

  5. MySQL 存储过程学习笔记

    存储过程框架 DEMILITER $$ -- 重定义符 DROP PROCEDURE IF EXISTS store_procedure$$ -- 如果存在此名的存储过程,先删除 CREATE PRO ...

  6. mysql存储过程学习第一天

    摘要:存储过程和函数是在数据库中定义一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句.存储过程和函数可以避免开发人员重复的编写相同的SQL语句.而且,存储过程和函数是在 ...

  7. mysql 存储过程学习(总)

    #一.存储过程和存储函数的创建案例 CREATE PROCEDURE myprocedure(in a int,in b int ,OUT c INT) BEGIN set c=a+b; end; c ...

  8. mysql 存储过程学习

    存储过程框架 DEMILITER $$ -- 重定义符 DROP PROCEDURE IF EXISTS store_procedure$$ -- 如果存在此名的存储过程,先删除 CREATE PRO ...

  9. mysql 存储过程学习 汇总

    存储过程框架 DEMILITER $$ -- 重定义符 DROP PROCEDURE IF EXISTS store_procedure$$ -- 如果存在此名的存储过程,先删除 CREATE PRO ...

随机推荐

  1. NOIP初赛 之 逻辑运算

    NOIP初赛 之 逻辑运算 逻辑运算先掌握各种运算,注意运算符的级别比较,做题是要细心.在NOIP中一般一题,分值为1.5分. 概念介绍: 非:not  ¬      与:and ∧      或:o ...

  2. Hadoop(六)之HDFS的存储原理(运行原理)

    前言 其实说到HDFS的存储原理,无非就是读操作和写操作,那接下来我们详细的看一下HDFS是怎么实现读写操作的! 一.HDFS读取过程 1)客户端通过调用FileSystem对象的open()来读取希 ...

  3. 吾八哥学Python(二):Python代码编辑器的选用

    Python开发环境配置好了,但发现自带的代码编辑器貌似用着有点不大习惯啊,所以咱们就找一个"好用的"代码编辑器吧,网上搜了一下资料,Python常用的编辑器有如下一些: 1. S ...

  4. win10 uwp 通知Toast

    win10通知使用Toast 可以使用win10 模板添加通知 var t = Windows.UI.Notifications.ToastTemplateType.ToastText02; 使用Ge ...

  5. win10 uwp 隐藏实时可视化

    新的vs有个功能,实时可视化 但是他会挡我们界面,想要隐藏 点击转到实时可视化,就是点击横线看到,接着就可以看到下面的选项 点击在应用程序中显示运行时,就是不选中 很简单就看到,没有那个 本作品采用知 ...

  6. VisualStudio 合并代码文件

    如果有相同的类,一般可以使用 partial 让他写在多个文件,那么如何把多个文件合并?请看 MainWindow.xaml 和 MainWindow.xaml.cs 其中 代码文件被折叠,那么如何做 ...

  7. Windows-universal-samples-master示例 XamlCommanding

    Windows-universal-samples-master XamlCommanding 运行默认如果是 ARM会出现没有引用System,只要在调试选择CPU为PC的就好 默认 选择PC平台 ...

  8. Java IO(IO流)-2

    IO流 第一部分 (OutputStreamWriter BufferOutputStream) 转换流 超类为Reader和Writer 是字符流通向字节流的桥梁:可使用指定的字符编码表,将要写入流 ...

  9. ios 返回不会自动刷新页面问题

    在实际开发过程中,移动端的兼容性问题有很大的坑,安卓可以了ios不行,ios可以了安卓又失效了这样,其中ios的回退操作就是不会自动刷新页面,很烦! 常见的history.back() history ...

  10. dubbo 笔记-XML配置文件简介

    <dubbo:service/> 服务配置,用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注册到多个注册中心. eg.<dubbo:service r ...