zoukankan      html  css  js  c++  java
  • 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 age<19;';
      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 age<19);
            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 age<p_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);

  • 相关阅读:
    微人事项目-mybatis-持久层
    通过外键连接多个表
    springioc
    Redis 消息中间件 ServiceStack.Redis 轻量级
    深度数据对接 链接服务器 数据传输
    sqlserver 抓取所有执行语句 SQL语句分析 死锁 抓取
    sqlserver 索引优化 CPU占用过高 执行分析 服务器检查
    sql server 远程备份 bak 删除
    冒泡排序
    多线程 异步 beginInvoke EndInvoke 使用
  • 原文地址:https://www.cnblogs.com/fengju/p/6336050.html
Copyright © 2011-2022 走看看