如何在MySQL中使用存储结构

38次阅读
没有评论

共计 2720 个字符,预计需要花费 7 分钟才能阅读完成。

自动写代码机器人,免费开通

这期内容当中丸趣 TV 小编将会给大家带来有关如何在 MySQL 中使用存储结构,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

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

上述就是丸趣 TV 小编为大家分享的如何在 MySQL 中使用存储结构了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注丸趣 TV 行业资讯频道。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计2720字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)