存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据库对象。
存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。
存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。
关键字delimiter ,下面语句代表将结束符号;修改为//
delimiter //
关键字DROP PROCEDURE,下面语句意思,如果存在存储过程名字是pro_test的,则删除该存储过程。
DROP PROCEDURE IF EXISTS pro_test//
关键字CREATE PROCEDURE,下面语句意思,创建名为pro_test的存储过程
CREATE PROCEDURE pro_test()
关键字begin为开始,end为结束,下面语句为开始与结束
BEGIN
#省略逻辑代码
END//
关键字call,调用存储过程
CALL pro_test();
delimiter //
DROP PROCEDURE IF EXISTS pro_test//
CREATE PROCEDURE pro_test()
BEGIN
select class_id,class_name from class_info;
END //
delimiter ;
CALL pro_test();
DROP TABLE IF EXISTS `class_info`;
CREATE TABLE `class_info` (
`class_id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`class_name` varchar(255) DEFAULT NULL COMMENT '班级名称',
PRIMARY KEY (`class_id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=gbk;
INSERT INTO `class_info` VALUES ('1', '17班');
INSERT INTO `class_info` VALUES ('2', '18班');
INSERT INTO `class_info` VALUES ('3', '19班');
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (
`student_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`studen_name` varchar(255) DEFAULT NULL COMMENT '学生姓名',
`student_class_id` int(10) unsigned NOT NULL COMMENT '关联班级表id',
PRIMARY KEY (`student_id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=gbk;
INSERT INTO `student` VALUES ('1', '张三', '1');
INSERT INTO `student` VALUES ('2', '李四', '1');
INSERT INTO `student` VALUES ('3', '王五', '1');
INSERT INTO `student` VALUES ('4', '测试', '4');