如何在MySQL中使用存储结构
发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,这期内容当中小编将会给大家带来有关如何在MySQL中使用存储结构,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.新建两张数据表:student1, student
千家信息网最后更新 2025年02月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安全错误
数据库的锁怎样保障安全
贵州尚品家互联网科技有限公司
国际版的jojo服务器
河北省ipfs服务器配置云空间
信息安全 网络安全管理规定
python怎么导数据库中
邢台4u机架式服务器价格
河北希幔软件开发有限公司
组成数据库管理系统的人员
智能边缘计算服务器怎么选择
lpv6网络安全白皮书
吉林语音网络技术服务市场价
通识课网络安全
lol 服务器卡
韶关机器人rpa软件开发
互联网企业科技技术革新
软件开发php和jA A区别
网络安全试卷1答案
mcu独立的综合管理服务器
服务器如何建立mysql数据库
上网行为管理服务器的连接
网络安全审计沟通协调机制
查看服务器硬盘容量总量
数据库的设计一般需要遵循
网络安全等级考试分数
厦门期货软件开发
宝塔面板默认的数据库访问地址
服务器夜间使用率
怎么拍网络安全宣传海报
安卓手机怎么加密数据库
苹果在哪个国家有服务器