存储函数与Locate和Substr方法模拟数组参数

5805次阅读 306人点赞 作者: WuBin 发布时间: 2021-06-17 11:18:05
扫码到手机查看

存储函数

我们先来看一个存储函数(在创建和使用存储函数时,一定要先使用数据库!)

-- 非常重要 要先选择数据库
use test;

delimiter //
create function bb() RETURNS int
begin
    declare pos int;
    declare cid int;
    declare mystr varchar(60) default "1,4,6";

    SET pos = locate(",", mystr);
    SET cid = substr(mystr, 1, pos);

    return cid;
end;
//
delimiter ;

delimiter

delimiter的作用:

默认情况下,mysql使用分号确定一个语句何时结束。但是在创建存储例程和存储函数的时候,需要编写多个语句(在begin和end中的语句需要使用分号进行分割), 所以必须将分隔符修改为另外一个字符串。所以在语句的开头要加上 delimiter // 意思为:将mysql执行分隔符改为// 

但是也要谨记,在end之后,一定要恢复执行分隔符为分号!

-- 修改默认的执行分隔符为 //
delimiter //
-- begin代码块开始
begin
....code
-- begin结束
end; 
-- 使用修改的执行分隔符结束
//
-- 恢复执行分隔符为分号
delimiter ;

注意!如果不设置delimiter可能在定义变量的时候,会出现如下错误:

create function bb() RETURNS int
begin
    declare pos int;
   ...
end;
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 3

有多少个DECLARE就会报多少次,然后后面就是取不到变量的报错。这个原因是没有定义delimiter。

这时就需要修改默认的分隔符后,再进行定义,问题就会解决:

delimiter //
create function bb() RETURNS int
begin
    declare pos int;
   ...
end;
//
delimiter ;

创建存储函数

语法: create func_name (参数) returns type 如:

create function bb() RETURNS int
begin
 ......
 return xx;
end;

需要注意的是 返回是returns!

声明和设置变量declare

变量声明语法: declare var_name type [default value]

必须声明一种mysql支持的类型。声明这些变量,必须注意如下事项:

  • 必须在begin/end代码块中
  • 且要在块中执行语句的前面
  • 变量的作用域限制在变量声明所在的代码块内
begin
  declare pos decimal(8, 2);
end;

如果需要设置变量的值,就需要使用SET:

begin
  declare pos decimal(8, 2);
  set pos = 2.34;
end;

特别提醒

如果将一个变量的类型设置为int,然后对其赋值一个字符串,那么最终得到的结果就是一个整型。比如像文章开头的例子那样:

declare cid int; // 变量类型为Int
SET cid = substr("1,4,5", 1, 2); // 截取字符串,得到1,
return cid; // 返回的值是整型,最终结果是1

如果变量赋值的类型与变量定义时的类型不匹配,那么mysql会自动对类型进行转换,转换为变量定义时的类型。

locate返回字符串在另一个字符串中的位置

语法:locate(str1, str2); 函数返回str1在str2中出现的位置。

  • 若str2中包含str1,则locate(str1, str2) > 0
  • 若str2不包含str1,则locate(str1, str2) = 0
select locate(',', '1,2,3,4');
// 最终得到2

mysql中的起始位置是从1开始的!请务必牢记!

substr截取字符串

语法:substr(str, pos, len) 从pos位开始,截取len个字符(len省略的话则从pos位置到字符串最后)

  • str:被截取的字符串
  • pos:起始位置,mysql中的起始位置从1开始,正数是从字符串左侧向右截取;负数则是从右侧向左侧截取;
  • len:截取字符的个数/长度
select substr('2021-06-17', 6); 
// 从第6位开始截取到字符串末尾,结果06-17

select substr('2021-06-17', 6, 2);
// 从第6位开始截取2个字符(的长度) 结果06

对存储函数的解析

-- 定义类型为整型的两个变量
declare pos int;
declare cid int;

-- 找到1,4,6中首个逗号的位置 得到位置是2
SET pos = locate(",", "1,4,6");
-- 从第字符串一个位置开始,截取pos(2)个字符,得到1,
SET cid = substr("1,4,6", 1, pos);
-- 由于cid定义的是整形,而得到的1,是字符串类型,所以会自动对类型转化
-- 得到cid的结果就是1
return cid;

所以最终运行存储函数bb() 得到的结果就是 1

参考《PHP与MYSQL程序设计(第五版)》 - P381页

相关资料

点赞 支持一下 觉得不错?客官您就稍微鼓励一下吧!
关键词:存储函数、Locate、substr
推荐阅读
  • uniapp实现被浏览器唤起的功能

    当用户打开h5链接时候,点击打开app若用户在已经安装过app的情况下直接打开app,若未安装过跳到应用市场下载安装这个功能在实现上主要分为两种场景,从普通浏览器唤醒以及从微信唤醒。

    8757次阅读 562人点赞 发布时间: 2022-12-14 16:34:53 立即查看
  • Vue

    盘点Vue2和Vue3的10种组件通信方式

    Vue中组件通信方式有很多,其中Vue2和Vue3实现起来也会有很多差异;本文将通过选项式API组合式API以及setup三种不同实现方式全面介绍Vue2和Vue3的组件通信方式。

    3674次阅读 274人点赞 发布时间: 2022-08-19 09:40:16 立即查看
  • JS

    几个高级前端常用的API

    推荐4个前端开发中常用的高端API,分别是MutationObserver、IntersectionObserver、getComputedstyle、getBoundingClientRect、requ...

    13765次阅读 888人点赞 发布时间: 2021-11-11 09:39:54 立即查看
  • PHP

    【正则】一些常用的正则表达式总结

    在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。了解一些常用的正则表达式,能大大提高你的工作效率。

    12532次阅读 422人点赞 发布时间: 2021-10-09 15:58:58 立即查看
  • 【中文】免费可商用字体下载与考证

    65款免费、可商用、无任何限制中文字体打包下载,这些字体都是经过长期验证,经得住市场考验的,让您规避被无良厂商起诉的风险。

    11032次阅读 881人点赞 发布时间: 2021-07-05 15:28:45 立即查看
  • Vue

    Vue3开发一个v-loading的自定义指令

    在vue3中实现一个自定义的指令,有助于我们简化开发,简化复用,通过一个指令的调用即可实现一些可高度复用的交互。

    15139次阅读 1207人点赞 发布时间: 2021-07-02 15:58:35 立即查看
  • JS

    关于手机上滚动穿透问题的解决

    当页面出现浮层的时候,滑动浮层的内容,正常情况下预期应该是浮层下边的内容不会滚动;然而事实并非如此。在PC上使用css即可解决,但是在手机端,情况就变的比较复杂,就需要禁止触摸事件才可以。

    14612次阅读 1191人点赞 发布时间: 2021-05-31 09:25:50 立即查看
  • Vue

    Vue+html2canvas截图空白的问题

    在使用vue做信网单页专题时,有海报生成的功能,这里推荐2个插件:一个是html2canvas,构造好DOM然后转canvas进行截图;另外使用vue-canvas-poster(这个截止到2021年3月...

    28356次阅读 2230人点赞 发布时间: 2021-03-02 09:04:51 立即查看
  • Vue

    vue-router4过度动画无效解决方案

    在初次使用vue3+vue-router4时候,先后遇到了过度动画transition进入和退出分别无效的情况,搜遍百度没没找到合适解决方法,包括vue-route4有一些API都进行了变化,以前的一些操...

    24466次阅读 1885人点赞 发布时间: 2021-02-23 13:37:20 立即查看
交流 收藏 目录