前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql存储过程----创建

mysql存储过程----创建

作者头像
用户5899361
发布2020-12-07 15:37:58
1.8K0
发布2020-12-07 15:37:58
举报
文章被收录于专栏:学习java的小白学习java的小白
概念:

存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据库对象。

存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。

存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。

优点
  • 存储过程可封装,并隐藏复杂的商业逻辑。
  • 存储过程可以回传值,并可以接受参数。
  • 存储过程无法使用 SELECT 指令来运行,因为它是子程序,与查看表,数据表或用户定义函数不同。
  • 存储过程可以用在数据检验,强制实行商业逻辑等。
缺点
  • 存储过程,往往定制化于特定的数据库上,因为支持的编程语言不同。当切换到其他厂商的数据库系统时,需要重写原有的存储过程。
  • 存储过程的性能调校与撰写,受限于各种数据库系统。
修改sql结束符号:

关键字delimiter ,下面语句代表将结束符号;修改为//

代码语言:javascript
复制
delimiter //
删除存储过程:

关键字DROP PROCEDURE,下面语句意思,如果存在存储过程名字是pro_test的,则删除该存储过程。

代码语言:javascript
复制
DROP PROCEDURE IF EXISTS pro_test//
创建存储过程:

关键字CREATE PROCEDURE,下面语句意思,创建名为pro_test的存储过程

代码语言:javascript
复制
CREATE PROCEDURE pro_test()
存储过程开始与结束:

关键字begin为开始,end为结束,下面语句为开始与结束

代码语言:javascript
复制
BEGIN
  #省略逻辑代码
END//
调用存储过程:

关键字call,调用存储过程

代码语言:javascript
复制
CALL pro_test();
存储过程完整代码:
代码语言:javascript
复制
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();
表结构:
代码语言:javascript
复制
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');
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 概念:
  • 优点
  • 缺点
  • 修改sql结束符号:
  • 删除存储过程:
  • 创建存储过程:
  • 存储过程开始与结束:
  • 调用存储过程:
  • 存储过程完整代码:
  • 表结构:
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档