SQL第19课——使用存储过程

介绍什么是存储过程?为什么要使用存储过程?如何使用存储过程?创建和使用存储过程的基本语法?

19.1 存储过程

到目前为止,使用的大多数SQL语句都是针对一个或多个表的单条语句。

对于一些复杂的操作需要多条语句才能完成。

情形:

  1. 处理订单,必须核对以保证库存中有相应的物品。

  2. 当物品有库存时,需要预定,不再出售给别人,并且减少物品数据反映正确的库存量;

当库存中没有的物品需要订购,需要与供应商进行某种交互;

  1. 哪些物品入库(可以立即发货),哪些物品退订,需要通知相应的顾客。

单独编写每条SQL语句,并根据结果有条件地执行其他语句。

**创建存储过程:**为以后使用而保存的一条或多条SQL语句。可将其视为文件,但作用不仅限于批处理。

SQLite不支持存储过程。

19.2 为什么要使用存储过程

|-----------------------------------------------------------|
| 1. 把处理封装在一个易用的单元中,可以简化复杂的操作 |
| 2. 由于不要求反复建立一系列处理步骤,保证了数据的一致性。(所有人使用同一个存储过程,则所使用的代码都是相同的) |
| 3. 从第2点延申为防止错误,保证了数据的一致性 |
| 4. 简化对变动的管理。(表名等有变化时,只需要更改存储过程的代码。使用人员不需要知道这些变化) |
| 5. 第4点延申为安全性。通过存储过程限制对基础数据的访问,减少了数据讹误的机会 |
| 6. 存储过程通常以编译过的形式存储,所以DBMS处理命令所需的工作量少,提高性能。 |
| 7. 存在一些只能用在单个请求中的SQL元素和特性,存储过程可以使用它们来编写功能更强更灵活的代码。 |
[使用存储过程的 主要好处]

简答 + 安全 + 高性能

|------------------------------------------------------------------------------------|
| 1. 不同DBMS的存储过程语法不同。但是存储过程的自我调节(名字以及数据如何传递)可以相对保持可移植。如果需要移植到别的DBMS上,至少客户端应用代码不需要变动。 |
| 2. 编写存储过程比编写基本SQL语句复杂。 需要更高的技能和更丰富的经验。 |
[SQL代码转换为存储过程前的 缺陷]

19.3 执行存储过程

存储过程的执行远比编写要频繁得多,用execute接受存储过程名和需要传递给它的任何参数。

存储过程所完成的工作:

  1. 验证传递的数据,保证所有参数都有值;

  2. 生成用作主键的唯一ID;

  3. 将新添加的东西插入到需要插入的表中,在合适的列中存储生成的主键和传递的数据。

19.4 创建存储过程

各种DBMS对存储过程的实现不一,需要根据使用的DBMS来参考具体的DBMS文档。不是很好说

相关推荐
百锦再13 分钟前
SQLSugar 封装原理详解:从架构到核心模块的底层实现
sql·mysql·sqlserver·架构·core·sqlsugar·net
亲爱的非洲野猪31 分钟前
时序数据库的 LSM 树介绍
数据库·时序数据库
熊文豪1 小时前
MySQL数据库迁移到KingbaseES完整指南
数据库·mysql·kingbasees·金仓数据库·kingbasees迁移指南
TDengine (老段)1 小时前
工业数据消费迎来“抖音式”革命:TDengine IDMP 让数据自己开口说话
大数据·数据库·物联网·ai·时序数据库·iot·tdengine
IDOlaoluo2 小时前
PLSQL Developer 12.0.1 x64 安装步骤详解(附Oracle连接设置|附安装包下载)
数据库·oracle
追逐时光者2 小时前
一款为程序员和运维人员量身打造的一站式开发运维利器
数据库·docker·ssh
往日情怀酿做酒 V17639296383 小时前
SQL注入6----(其他注入手法)
数据库·sql
代码的余温3 小时前
Redis vs Elasticsearch:核心区别深度解析
大数据·数据库·redis·elasticsearch
forestsea3 小时前
Nacos-3.0.3 适配PostgreSQL数据库
数据库·postgresql
一 乐3 小时前
医院排班|医护人员排班系统|基于springboot医护人员排班系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·医护人员排班系统