MySQL (九)-- 代码执行结构、函数、存储过程
1 代码执行结构
- 代码执行结构有三种:顺序结构、分支结构和循环结构。
1.1 分支结构
- 分支结构:实现准备多个代码块,按照条件选择性执行某段代码。
- 在MySQL中只有if分支。
- 基本语法
if 条件判断 then -- 满足条件要执行的代码 else if -- 不满足条件要执行的代码 else -- 不满足条件要执行的代码 end if;
- 触发器结合if分支:判断商品库存是否足够,不够不能生成订单。
-- 触发器结合if分支,判断商品库存是否足够,不够不能生成订单
DELIMITER $$
CREATE TRIGGER insert_before BEFORE INSERT ON `ORDER` FOR EACH ROW
BEGIN
-- 判断商品库存是否足够
-- 获取商品库存:商品库存在表中
SELECT inv FROM goods WHERE id = new.g_id INTO @inv;
-- 比较kuc
IF @inv < new.g_number THEN -- 库存不够
-- 触发器没有提供一个能够阻止事件发生的能力,只能暴力报错
INSERT INTO xxx VALUES(xxx);
END IF;
END
$$
DELIMITER ;
1.2 循环结构
- 循环结构:某段代码在指定条件下执行。
- while循环
while 条件判断 do -- 满足条件要执行的代码 -- 变更循环条件 end while;
循环控制:在循环内部进行循环判断和控制 MySQL中没有对应的continue和break; iterate:类似于continue leave:类似于break
iterate和leave的使用方式: iterate/leave 循环名字;
-- 定义循环名字
循环名字:while 条件 do
-- 循环体
-- 循环控制
end while;
2 函数
- 函数:将一段代码块封装到一个结构中,在需要执行代码块的时候,调用结构执行即可(代码复用)。
- 函数分为两类:系统函数和自定义函数。
2.1 系统函数
- 系统定义好的函数,直接调用即可。
- 任何函数都有返回值,因此函数的调用都是通过select调用。
- substring(str,offset,len):从offset(MySQL中的自妇产的下标是从1)开始,截取长度是len。
SET @cn = '世界你好'; SET @en = "hello world"; -- 字符串截取 ,),,);

- char_length:字符长度
- length:字节长度
SET @cn = '世界你好'; SET @en = "hello world"; -- 字符串长度 SELECT CHAR_LENGTH(@cn),CHAR_LENGTH(@en),LENGTH(@cn),LENGTH(@en);

- instr:判断字符串是否在某个字符串中存在,存在,返回位置;失败,返回0。
SET @cn = '世界你好'; SET @en = "hello world"; SELECT INSTR(@cn,'你');

SELECT INSTR(@cn,'哈哈');

- Lpad:左填充,将字符串按照某个指定的填充方式,填充到指定长度。
SET @cn = '世界你好'; SET @en = "hello world"; ,'呵呵');

- strcmp:compare,字符串比较,小,就返回-1;相等,就返回0;大,就返回1。
SET @a = 'hello'; SET @b = 'hei'; SET @c = 'HEI'; SELECT STRCMP(@a,@b),STRCMP(@b,@c),STRCMP(@c,@a);

2.2 自定义函数
- 函数要素:函数名,参数列表,返回值,函数体(作用域)。
- 创建函数
-- 创建函数
CREATE FUNCTION 函数名([形参列表]) RETURNS 数据类型
BEGIN
-- 函数体
-- 返回值
RETURN 返回值(指定数据类型);
END;
DELIMITER $$
CREATE FUNCTION dis() RETURNS INT
BEGIN
;
END
$$
DELIMITER ;
- 自定义函数和系统函数调用方式是一样的。
SELECT dis();

2.3 查看函数
- 查看所有函数:
show function status [like 'pattern'];

- 查看创建函数语句

2.4 修改函数&删除函数
- 函数不可以修改,只能先删除,再新增函数。
- 删除函数的基本语句
drop function 函数名;

2.5 函数参数
- 函数分为两种:定义的参数叫形参,调用时的参数叫实参。
- 形参:必须指定数据类型
DELIMITER $$ CREATE FUNCTION 函数名 (形参名字 数据类型) RETURNS 数据类型 BEGIN -- 函数体 -- 返回值 RETURN 返回值; END; $$ DELIMITER ;
DELIMITER $$
CREATE FUNCTION res (num INT) RETURNS INT
BEGIN
;
;
WHILE @i <= num DO
SET @sum = @sum + @i;
;
END WHILE;
RETURN @sum;
END;
$$
DELIMITER ;
);

- 在函数内部定义的@变量在函数外部也可以使用。

2.6 函数的作用域
- MySQL中的作用域与js中的作用域完全一样。
- 全局变量可以在任何地方使用;局部变量只能在函数内部使用。
- 全局变量:使用set关键字定义,使用@符号定义。
- 局部变量:使用declare关键字声明,没有@符号,所有的局部变量的声明,必须在函数体开始之前。
DELIMITER $$
CREATE FUNCTION res (num INT) RETURNS INT
BEGIN
;
;
WHILE i <= num DO
SET SUM = SUM +i;
;
END WHILE;
RETURN SUM;
END;
$$
DELIMITER ;


3 存储过程
- 存储过程:简称过程,procedure,是一种用来处理数据的方式。
- 存储过程是一个没有返回值的函数。
3.1 创建存储过程
- 基本语法
DELIMITER $$ CREATE PROCEDURE 过程名字([参数列表]) BEGIN -- 过程体 END $$ DELIMITER ;
DELIMITER $$ CREATE PROCEDURE proe() BEGIN -- 过程体 SELECT * FROM my_account; END $$ DELIMITER ;

3.2 查看存储过程
- 函数的查看方式完全使用与存储过程。
- 查看所有的存储过程。
- show procedure status [like 'pattern'];
SHOW PROCEDURE STATUS;

- 查看创建过程语句
- show create procedure 存储过程名字;

3.3 调用过程
- 因为存储过程是没有返回值的,所以不能使用select关键字。
- 调用存储过程,使用call关键字。
call 存储过程的名字;
CALL proe();

3.4 修改过程&删除过程
- 存储过程不可以修改,只能先删除,再新增存储过后才能。
- 删除存储过程
drop 存储过程的名字;

3.5 存储过程参数类型
- 函数的参数需要数据类型指定,过程比函数更严格。
- 过程还有自己的类型限定:三种类型
- ① in:数据从外部传入给内部使用(值传递):可以是数值也可以是变量
- ②out:只允许过程内部使用(不用外部数据),给外部使用的(引用传递,外部的数据会被先清空才进入内部),只能是变量。
- ③inout:外部的可以在内部使用,内部修改也可以给外部使用,典型的引用传递,只能传递变量。
- 基本语法
DELIMITER $$
CREATE PROCEDURE 过程名 (IN 形参名称 数据类型,OUT 形参名称 数据类型,INOUT 形参名称 数据类型)
BEGIN
-- 过程体
END;
$$
DELIMITER ;
DELIMITER $$
CREATE PROCEDURE pro1 (IN int_1 INT,OUT int_2 INT,INOUT int_3 INT)
BEGIN
-- 过程体
SELECT INT_1,INT_2,INT_3;
END;
$$
DELIMITER ;
- 调用:out和inout类型的参数必须传入变量,而不是是数值。
; ; ; SELECT @int_1,@int_2,@int_3; CALL pro1(@int_1,@int_2,@int_3); SELECT @int_1,@int_2,@int_3;

MySQL (九)-- 代码执行结构、函数、存储过程的更多相关文章
- mysql之代码执行结构
本文内容: 什么是代码执行结构 顺序结构 分支结构 循环结构 首发日期:2018-04-18 什么是代码执行结构: 这里所说的代码执行结构就是多条sql语句的执行顺序. 代码执行结构主要用于触发器.存 ...
- PHP常见代码执行后门函数
PHP常见代码执行后门函数 代码执行: 应用程序在调用一些能够将字符串转换为代码的函数(例如php中的eval中),没有考虑用户是否控制这个字符串,将造成代码执行漏洞. 常见php代码执行函数介绍 常 ...
- MySQL mysqldump 导入/导出 结构&数据&存储过程&函数&事件&触发器
———————————————-库操作———————————————-1.①导出一个库结构 mysqldump -d dbname -u root -p > xxx.sql ②导出多个库结构 m ...
- 基本开题的感觉是了-MySQL继续继续(自定义函数&存储过程)
hi 感觉论文开题基本确定了,凯森 1.MySQL -----自定义函数----- ----基本 两个必要条件:参数和返回值(两者没有必然联系,参数不一定有,返回一定有) 函数体:合法的SQL语句:以 ...
- mysql九大类常用函数
一.数学函数 ABS(x) 返回x的绝对值BIN(x) 返回x的二进制(OCT返回八进制,HEX返回十六进制)CEILING(x) 返回大于x的最小整数值EXP(x) 返回值e(自然对数的底)的x次方 ...
- 将字符串当做是php代码执行的函数eavl()
- Pikachu-RCE(远程命令/代码执行漏洞)
RCE(remote command/code execute)概述 RCE漏洞,可以让攻击者直接向后台服务器远程注入操作系统命令或者代码,从而控制后台系统. 远程系统命令执行一般出现这种漏洞,是因为 ...
- PHP安全(文件包含、变量覆盖、代码执行)
文件包含漏洞 本地文件包含 截断技巧: ../../etc/passwd%00(\x00 \0) 利用操作系统对目录最大长度的限制,可以不需要0字节而达到截断的目的.目录字符串,在windows下25 ...
- MySql(十九):基础——自定义存储过程和函数
MYSQL中创建存储过程和函数分别使用CREATE PROCEDURE和CREATE FUNCTION 使用CALL语句来调用存储过程,存储过程也可以调用其他存储过程 函数可以从语句外调用,能返回标量 ...
随机推荐
- [Git] 1、常用Git命令行总结(一)
一.GIT CLONE最常用的有如下几个 1.最简单直接的命令:git clone xxx.git 2.如果想clone到指定目录:git clone xxx.git “指定目录” 3.clone时创 ...
- python--DenyHttp项目(1)--GUI:tkinter☞ module 'tkinter' has no attribute 'messagebox'
AttributeError: module 'tkinter' has no attribute 'messagebox' improt tkinter from tkinter import * ...
- hdu--5351--MZL's Border
表示看这篇博客后找到了思路: http://blog.csdn.net/queuelovestack/article/details/47291195 补充一下数据,方便观察规律 m LBorder ...
- vue指令v-show示例解析
v-show控制元素显示或者隐藏: <div id="app"> <p v-show="isShow">this is a messag ...
- 给View添加手势,防止点击View上其他视图触发点击效果
在开发过程中,我们可能会遇到这个问题. 当我们给一个view添加了手势,但是我们又不想点击view上面的视图也触发手势.如下图: 我们在红色view上添加了手势,但是又不想点击黄色view也触发.其实 ...
- BFS:noi6044鸣人与佐助
PS:一道XX到我心态崩溃的好(傻逼)题. 先粘题目: 佐助被大蛇丸诱骗走了,鸣人在多少时间内能追上他呢? 已知一张地图(以二维矩阵的形式表示)以及佐助和鸣人的位置.地图上的每个位置都可以走到,只不过 ...
- ecshop中的些assign_dynamic(’')
很多做电子商务站的朋友都问我,在ecshop中,里面有个 assign_dynamic('index');这个到底是什么作用来的,这个其实是ecshop中的模板技术,动态处理一些局部信息更新而不被缓存 ...
- 初探IAT
---恢复内容开始--- IAT(Import Address Table:输入函数地址表) [IAT作用是什么:] 一个API函数,比如MessageBoxA,我们是如何调用它的呢, 在这里我们可以 ...
- Linux - 简明Shell编程09 - 重定向(Redirection)
脚本地址 https://github.com/anliven/L-Shell/tree/master/Shell-Basics 示例脚本及注释 #!/bin/bash pwd > 1.log ...
- Jedis与Redisson选型对比
1 概述 1.1. 主要内容 本文的主要内容为对比Redis的两个框架:Jedis与Redisson,分析各自的优势与缺点,为无线云管理项目中Redis编程模型的选择提供参考. 2. ...