mysql笔记:17. 数据库编程

文章目录

  • 一、存储过程
    • [1. 创建存储过程](#1. 创建存储过程)
    • [2. 查看存储过程](#2. 查看存储过程)
    • [3. 调用存储过程](#3. 调用存储过程)
    • [4. 修改存储过程](#4. 修改存储过程)
    • [5. 删除存储过程](#5. 删除存储过程)
  • 二、函数
    • [1. 创建自定义函数](#1. 创建自定义函数)
    • [2. 查看自定义函数](#2. 查看自定义函数)
    • [3. 调用自定义函数](#3. 调用自定义函数)
    • [4. 删除自定义函数](#4. 删除自定义函数)

为了提高SQL语句的重用性,MySQL可以将频繁使用的业务逻辑封装成程序进行存储,这类程序包括存储过程、函数、触发器等。

一、存储过程

存储过程是一组可以完成特定功能的SQL语句集合,它可以将常用或复杂操作封装成一个代码块存储在数据库服务器中,以便重复使用,大大减少数据库开发人员的工作量。

1. 创建存储过程

基本语法:

SQL 复制代码
CREATE PROCEDURE pro_name([[IN | OUT | INOUT ] 参数名称 参数类型]) [characteristic ... ] routine_body

MySQL默认的语句结束符号为分号(;),而在创建存储过程时,存储过程体可能包含多条SQL语句,所以为避免分号与存储过程中SQL语句的结束符相冲突,需要使用DELIMITER改变存储过程的结束符。存储过程定义完毕后再恢复默认结束符。

SQL 复制代码
mysql> DELIMITER //

2. 查看存储过程

存储过程创建之后,可以使用SHOW PROCEDURE STATUS语句和SHOW CREATE PROCEDURE语句分别显示存储过程的状态信息和创建信息,也可以在数据库information_schema的Routines数据表中查询。

SQL 复制代码
mysql> SHOW PROCEDURE STATUS [LIKE 'pattern'];
mysql> SHOW CREATE PROCEDURE pro_name;

3. 调用存储过程

基本语法:

SQL 复制代码
mysql> CALL [dbname.]pro_name([实参列表]);

4. 修改存储过程

基本语法:

SQL 复制代码
mysql> ALTER PROCEDURE pro_name[characteristic ... ];

只能修改存储过程的特征值,不能修改存储过程的参数

5. 删除存储过程

基本语法:

SQL 复制代码
mysql> DROP PROCEDURE [IF EXISTS] pro_name;

二、函数

MySQL支持函数的使用,其中的函数分为两种:内置函数、自定义函数。自定义函数和内置函数性质相同,都用于实现某种功能。

1. 创建自定义函数

自定义函数和存储过程类似,都是存储在数据库中的一段SQL语句集合;区别在于存储过程没有直接返回值,主要用于执行操作,而自定义函数可以通过RETURN语句返回数据。创建自定义函数的基本语法:

SQL 复制代码
CREATE FUNCTION func_name([func_parameter[...]]) RETURNS type [characteristic ... ] Routine_body

2. 查看自定义函数

自定义函数创建之后,可以使用SHOW FUNCTION STATUS语句和SHOW CREATE FUNCTION语句分别显示存储过程的状态信息和创建信息,也可以在数据库information_schema的Routines数据表中查询。

SQL 复制代码
mysql> SHOW FUNCTION STATUS [LIKE 'pattern'];
mysql> SHOW CREATE FUNCTION func_name;

从语法来看,查看存储过程和自定义函数相似,只是使用的关键字不同。

3. 调用自定义函数

自定义函数的调用和MySQL内置函数的调用类似,基本语法:

SQL 复制代码
mysql> SELECT func_name(parameters) [, func_name(parameters) ... ];

4. 删除自定义函数

SQL 复制代码
mysql> DROP FUNCTION [IF EXISTS] func_name;
相关推荐
2401_835956811 分钟前
Golang怎么写基准测试benchmark_Golang基准测试教程【完整】
jvm·数据库·python
南境十里·墨染春水26 分钟前
C++ 笔记 thread
java·开发语言·c++·笔记·学习
南境十里·墨染春水28 分钟前
C++ 笔记 高级线程同步原语与线程池实现
java·开发语言·c++·笔记·学习
lkforce35 分钟前
MiniMind学习笔记(二)--model_minimind.py
笔记·python·学习·minimind·minimindconfig
阿杰学AI40 分钟前
AI核心知识129—大语言模型之 向量数据库(简洁且通俗易懂版)
数据库·人工智能·ai·语言模型·自然语言处理·向量数据库·vector database
SPC的存折42 分钟前
D在 Alpine 容器中手动搭建 Discuz 全攻略(包含镜像一键部署脚本,可直接用)
linux·数据库·mysql·缓存
李兆龙的博客1 小时前
从一到无穷大 #67 大查询根因分析 - 从 PinSQL 到 RCRank
数据库·时序数据库
AgCl231 小时前
MYSQL-6-函数与约束-3/17
android·数据库·mysql
junqiduhang1 小时前
Win11 MySQL 8.0 安装八步走
数据库·mysql
zhangchaoxies1 小时前
golang如何使用SQLx原生SQL查询_golang SQLx原生SQL查询使用方法
jvm·数据库·python