• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL存储结构用法案例分析

    本文实例讲述了MySQL存储结构用法。分享给大家供大家参考,具体如下:

    前言

    今天公司老大让我做一个MySQL的调研工作,是关于MySQL的存储结构的使用。这里我会通过3个例子来介绍一下MySQL中存储结构的使用过程,以及一些需要注意的点。

    笔者环境

    系统:Windows 7

    MySQL:MySQL 5.0.96

    准备工作

    1.新建两张数据表:student1, student2

    新建student1

    DROP TABLE IF EXISTS student1;
    CREATE TABLE student1 (
    id INT NOT NULL auto_increment,
    name TEXT,
    age INT,
    PRIMARY KEY(id)
    );
    
    

    新建student2

    DROP TABLE IF EXISTS student2;
    CREATE TABLE student2 (
    id INT NOT NULL auto_increment,
    name TEXT,
    age INT,
    PRIMARY KEY(id)
    );
    
    

    2.向student1中新增数据

    INSERT INTO student1 (name, age) VALUES ('xiaoming', 18);
    INSERT INTO student1 (name, age) VALUES ('xiaohong', 17);
    INSERT INTO student1 (name, age) VALUES ('xiaogang', 19);
    INSERT INTO student1 (name, age) VALUES ('xiaoyu', 18);
    INSERT INTO student1 (name, age) VALUES ('xiaohua', 20);
    
    

    实现功能说明

    1.打印student1中的部分信息

    2.把student1中的部分数据复制到student2中

    3.传入参数作为限制条件,把student1中的部分数据复制到student2中

    注意事项

    在编写存储结构的时候,我们不能以分号(;)结束。因为我们的SQL语句就是以分号(;)结尾的。这里我们要修改一下存储结构的结束符号()。

    这里我们使用MySQL中的DELIMITER进行修改,并在存储结构创建完毕时,再改为分号(;)结束即可。

    关于这一点在后面的例子中有所体现。在编写MySQL的触发器中,也会用到类似的情况。

    使用方式

    1.打印student1中的部分信息

    ---------------------------------------------------------------
    DROP PROCEDURE IF EXISTS test_pro1;
    ---------------------------------------------------------------
    DELIMITER 
    CREATE PROCEDURE test_pro1()
    BEGIN
     set @sentence = 'select * from student1 where age19;';
     prepare stmt from @sentence;
     execute stmt;
     deallocate prepare stmt;
    END 
    DELIMITER ;
    
    

    2.复制表存储过程的编写(不带参数)

    ---------------------------------------------------------------
    DROP PROCEDURE IF EXISTS test_pro2;
    ---------------------------------------------------------------
    DELIMITER 
    create procedure test_pro2()
    begin
      DECLARE stop_flag INT DEFAULT 0;
      DECLARE s_name TEXT default '';
      DECLARE s_age INT default 0;
      DECLARE cur1 CURSOR FOR (select name, age from student1 where age19);
        DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET stop_flag=1;
      open cur1;
        fetch cur1 into s_name, s_age;
      while stop_flag>1 DO
        insert into student2(name, age) values(s_name, s_age);
        fetch cur1 into s_name, s_age;
      end while;
      close cur1;
    end 
    DELIMITER ;
    
    

    3.复制表存储过程的编写(带参数)

    ---------------------------------------------------------------
    DROP PROCEDURE IF EXISTS test_pro3;
    ---------------------------------------------------------------
    DELIMITER 
    create procedure test_pro3(IN p_age INT)
    begin
      DECLARE stop_flag INT DEFAULT 0;
      DECLARE s_name TEXT default '';
      DECLARE s_age INT default 0;
      DECLARE cur1 CURSOR FOR (select name, age from student1 where agep_age);
        DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET stop_flag=1;
      open cur1;
        fetch cur1 into s_name, s_age;
      while stop_flag>1 DO
        insert into student2(name, age) values(s_name, s_age);
        fetch cur1 into s_name, s_age;
      end while;
      close cur1;
    end 
    DELIMITER ;
    
    

    这里的SQLSTATE '02000'和NOT FOUND系统返回值是一样的。

    4.使用方式

    call test_pro1();
    
    

    or

    call test_pro1(123);
    
    

    更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL存储过程技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》及《MySQL数据库锁相关技巧汇总》

    希望本文所述对大家MySQL数据库计有所帮助。

    您可能感兴趣的文章:
    • MySQL两种表存储结构MyISAM和InnoDB的性能比较测试
    • Mysql通过Adjacency List(邻接表)存储树形结构
    • mysql 存储过程中变量的定义与赋值操作
    • mysql存储过程详解
    • 更改Mysql数据库存储位置的具体步骤
    • mysql存储过程 游标 循环使用介绍
    • mysql 海量数据的存储和访问解决方案
    • MySQL存储引擎总结
    • MySQL存储毫秒数据的方法
    • MySql存储过程与函数详解
    上一篇:Mysql实现增量恢复的方法详解
    下一篇:关于MySQL中的查询开销查看方法详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL存储结构用法案例分析 MySQL,存储,结构,用法,案例分析,