SQL深入探究存储的过程

 更新时间:2023年01月05日 08:56:18   作者:黑码哥  
存储过程是事先经经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于高效数据处理的效率是有好处的

现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同

时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据。

步骤:

使用SELECT语句查询新学生的老师是否存在于老师表中;

  • 如果不存在 ,则继续执行第2步;
  • 如果存在,则直接跳到第3步;

向老师表中插入老师数据;向学生表中插入学生数据

上方需求我们可以通过存储过程实现

存储过程简介

现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同

时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据

存储过程:一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,然后通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。

存储过程的创建及调用

存储过程的创建:使用关键字CREATE PROCEDURE

存储过程的删除

如何删除存储过程

比如:现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据。

CREATE PROCEDURE sp_add_student(
IN i_student_id VARCHAR(50), IN i_student_name VARCHAR(100),
IN i_gender VARCHAR(10), IN i_birth_day DATE,
IN i_age INT, IN i_class_id VARCHAR(50),
IN i_score DECIMAL(18,2), IN i_teacher_id VARCHAR(20)
)
BEGIN
IF NOT EXISTS(SELECT 1 FROM teacher WHERE teacher_id = 'i_teacher_id') THEN
INSERT INTO teacher(teacher_id) VALUES (i_teacher_id);
END IF;
INSERT INTO student VALUES(
i_student_id,i_student_name,i_gender,i_birth_day,
i_age, i_class_id, i_score, i_teacher_id
);
END;

存储过程的调用:使用关键字CALL

如:

CALL sp_add_student( 
'S20170091', '杨艳', '女', '2003-04-09',
15, 'G0206', 89.23, 'T0021' 
);

存储过程的删除:使用关键字DROP PROCEDURE

如:DROP PROCEDURE sp_add_student;

存储过程的优缺点

优点:

  • 功能强大、灵活性高;
  • 模块化,封装,代码复用;

缺点:

  • 开发调试困难;
  • 可移植性差,不同数据库,语法差别很大,移植困难;

到此这篇关于SQL深入探究存储的过程的文章就介绍到这了,更多相关SQL存储过程内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MYSQL8 通过ibd文件恢复表数据的方法

    MYSQL8 通过ibd文件恢复表数据的方法

    这篇文章主要介绍了MYSQL8 通过ibd文件恢复表数据的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • 使用Linux的Shell脚本定时处理MySQL超时

    使用Linux的Shell脚本定时处理MySQL超时

    本文提供使用Linux的Shell脚本定时处理MySQL超时Locked进程脚本
    2013-11-11
  • mysql如何通过my.ini更改默认字符集

    mysql如何通过my.ini更改默认字符集

    这篇文章主要介绍了mysql如何通过my.ini更改默认字符集问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Nacos配置MySQL8的方法

    Nacos配置MySQL8的方法

    这篇文章主要介绍了Nacos配置MySQL8的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • windows下mysql 8.0.16 安装配置方法图文教程

    windows下mysql 8.0.16 安装配置方法图文教程

    这篇文章主要为大家详细介绍了windows下mysql 8.0.16 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • MySQL中Case When用法及说明

    MySQL中Case When用法及说明

    这篇文章主要介绍了MySQL中Case When用法及说明,具有很好的参考价值,希望对大家有所帮助。
    2022-12-12
  • Mac下安装mysql5.7 完整步骤(图文详解)

    Mac下安装mysql5.7 完整步骤(图文详解)

    本篇文章主要介绍了Mac下安装mysql5.7 完整步骤,具有一定的参考价值,有兴趣的可以了解一下,
    2017-01-01
  • MySQL Version确认问题(版本确认)

    MySQL Version确认问题(版本确认)

    这篇文章主要介绍了MySQL Version确认问题(版本确认),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • MySQL中查询json格式的字段实例详解

    MySQL中查询json格式的字段实例详解

    这篇文章主要给大家介绍了关于MySQL中查询json格式字段的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • 详解Mysql通讯协议

    详解Mysql通讯协议

    这篇文章对Mysql的通讯协议做了详细介绍和说明,希望我们整理的内容对你有用,一起学习下吧。
    2017-12-12

最新评论