1. 首页
  2. 技术知识

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 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);

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

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

原创文章,作者:starterknow,如若转载,请注明出处:https://www.starterknow.com/115013.html

联系我们