如何在MySQL中使用存储结构
发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,这期内容当中小编将会给大家带来有关如何在MySQL中使用存储结构,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.新建两张数据表:student1, student
千家信息网最后更新 2024年11月23日如何在MySQL中使用存储结构
这期内容当中小编将会给大家带来有关如何在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<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 age1 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中使用存储结构了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。
存储
结构
数据
部分
分号
参数
信息
内容
方式
过程
分析
专业
中小
事项
例子
内容丰富
功能
就是
情况
数据表
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络技术人都混什么网站
地平线4突然无法连接服务器
诺格网络安全
蜘蛛网络安全团队官方网站
led屏软件开发
色弱可以学网络安全专业吗
软件开发项目价值
关于网络安全的英文小短文
lwip只能做一个服务器吗
软件开发属于什么行业特点
郑州哪里可以学软件开发
计算机网络技术冗余码计算
腾讯云服务器添加用户
承德超融合服务器公司
数据库性别变问号
数据库安装实例名不能选默认
服务器的管理与配置dhcp
大同网络安全主题教育
山西java软件开发价格行情
战地3 服务器
数据库分离语法
软件开发公司的基本运行方式
服务器审计管理员权限
CDM技术只保护数据库吗
通用软件开发工程师工资
迭代服务器端是什么
我的世界动画服务器争夺战02
万方数据库检索报告
河南蓝果网络技术 怎么样
机器学习与网络技术