本文地址:http://www.cnblogs.com/qiaoyihang/p/6250684.html


-- /*
-- * 用于获取一记录数据,根据传入的分隔字符delim,索引位置pos,返回相对应的value
-- * SELECT Json_getKeyValue({"A":"2","B":"0","C":"1","D":"1"},'A');
-- */
DELIMITER $$

DROP FUNCTION IF EXISTS `Json_getKeyValue` $$

CREATE DEFINER=`root`@`%` FUNCTION `Json_getKeyValue`(
in_JsonArray VARCHAR(4096), #JSON数组字符串
in_KeyName VARCHAR(64) #键名
) RETURNS VARCHAR(512) CHARSET utf8 BEGIN
DECLARE vs_return VARCHAR(4096);
DECLARE vs_JsonArray, vs_Json, vs_KeyName VARCHAR(4096);
DECLARE vi_pos1, vi_pos2 SMALLINT UNSIGNED; SET vs_JsonArray = TRIM(in_JsonArray);
SET vs_KeyName = TRIM(in_KeyName); IF vs_JsonArray = '' OR vs_JsonArray IS NULL
OR vs_KeyName = '' OR vs_KeyName IS NULL
THEN
SET vs_return = NULL;
ELSE
#去掉方括号
SET vs_JsonArray = REPLACE(REPLACE(vs_JsonArray, '[', ''), ']', '');
#取指定的JSON对象
SET vs_json = SUBSTRING_INDEX(vs_JsonArray,'}',-1); IF vs_json = '' OR vs_json IS NULL THEN
SET vs_return = NULL;
ELSE
SET vs_KeyName = CONCAT('"', vs_KeyName, '":');
SET vi_pos1 = INSTR(vs_json, vs_KeyName); IF vi_pos1 > 0 THEN
#如果键名存在
SET vi_pos1 = vi_pos1 + CHAR_LENGTH(vs_KeyName);
SET vi_pos2 = LOCATE(',', vs_json, vi_pos1); IF vi_pos2 = 0 THEN
#最后一个元素没有','分隔符,也没有结束符'}'
SET vi_pos2 = CHAR_LENGTH(vs_json) + 1;
END IF; SET vs_return = REPLACE(MID(vs_json, vi_pos1, vi_pos2 - vi_pos1), '"', '');
END IF;
END IF;
END IF; RETURN(vs_return);
END$$ DELIMITER ;
-- /*
-- * str_split(str,delim,pos)函数
-- * 用于获取一记录数据,根据传入的分隔字符delim,索引位置pos,返回相对应的value
-- * 如:str_split("aa,bb,cc", ",", 1) 则返回aa
-- */
DROP FUNCTION IF EXISTS str_split;
CREATE FUNCTION str_split
(
str VARCHAR(255),
delim VARCHAR(12),
pos INT
) RETURNS varchar(255)
begin
RETURN REPLACE(SUBSTRING(SUBSTRING_INDEX(str, delim, pos),LENGTH(SUBSTRING_INDEX(str,delim, pos -1)) + 1),delim,'');
end
-- /*
-- * get_distance(lng1,lat1,lng2,lat2)函数
-- * 根据地理两点的经纬度返回距离
-- */
DROP FUNCTION IF EXISTS get_distance;
create FUNCTION get_distance
(
lng1 DECIMAL(12,6),
lat1 DECIMAL(12,6),
lng2 DECIMAL(12,6),
lat2 DECIMAL(12,6)
)
RETURNS INT
BEGIN
RETURN round(6378.138*2*asin(sqrt(pow(sin( (lat1*pi()/180-lat2*pi()/180)/2),2)+cos(lat1*pi()/180)*cos(lat2*pi()/180)* pow(sin( (lng1*pi()/180-lng2*pi()/180)/2),2)))*1000);
END
-- /*
-- * map_get(map,inputKey)函数
-- * 用于解析map结构的数据,根据传入的inputKey返回相对应的value
-- */
DROP FUNCTION IF EXISTS map_get;
CREATE FUNCTION map_get(
map varchar(5000),
inputKey varchar(300)
)
RETURNS VARCHAR(255)
BEGIN
DECLARE rowSeperator char(1) default ';'; -- 行分隔符
DECLARE fieldSeperator char(1) default '='; -- 键值对分隔符 DECLARE tempMap varchar(255) default map;
DECLARE isEnd boolean default false; DECLARE rowIndex int default 0;
DECLARE pair varchar(255);
DECLARE pairIndex varchar(255);
DECLARE strKey varchar(255);
DECLARE strValue varchar(255); WHILE isEnd = false do set rowIndex = locate(rowSeperator,tempMap);
if rowIndex > 0 then
set pair = substring(tempMap,1,rowIndex-1);
set tempMap = substring(tempMap,rowIndex+1,9999999);
else
set pair = tempMap;
set isEnd = true;
end if; set pairIndex = locate(fieldSeperator,pair);
if pairIndex > 0 then
set strKey = substring(pair,1,pairIndex-1);
set strValue = substring(pair,pairIndex+1,9999999);
if inputKey = strKey then
return strValue;
end if;
end if; END WHILE; return null;
END
-- /*
-- * map_get_json(map,inputKey)函数
-- * 用于解析JSON目标结构的数据,根据传入的inputKey返回相对应的value
-- * 一时没找到标准的解析JSON的自定义函数,就自己写了一个纯按字符串拆分获取的函数,记录数不是很大,json目标也不是很复杂,基本也可以用
-- */
DROP FUNCTION IF EXISTS map_get_json;
CREATE FUNCTION map_get_json(
map varchar(5000),
inputKey varchar(300)
)
RETURNS VARCHAR(255)
BEGIN
DECLARE rowSeperator char(1) default ','; -- 行分隔符
DECLARE fieldSeperator char(1) default ':'; -- 键值对分隔符 DECLARE tempMap varchar(1024) default map;
DECLARE isEnd boolean default false; DECLARE rowIndex int default 0;
DECLARE pair varchar(255);
DECLARE pairIndex varchar(255);
DECLARE strKey varchar(255);
DECLARE strValue varchar(255); set tempMap = trim(map);
set tempMap = replace(substring(tempMap, 2, length(tempMap)-2), '"', ''); WHILE isEnd = false do set rowIndex = locate(rowSeperator,tempMap);
if rowIndex > 0 then
set pair = substring(tempMap,1,rowIndex-1);
set tempMap = substring(tempMap,rowIndex+1,9999999);
else
set pair = tempMap;
set isEnd = true;
end if; set pairIndex = locate(fieldSeperator,pair);
if pairIndex > 0 then
set strKey = trim(substring(pair,1,pairIndex-1));
set strValue = trim(substring(pair,pairIndex+1,9999999));
if inputKey = strKey then
return trim(strValue);
end if;
end if; END WHILE; return null;
END

mysql 常用自定义函数解析的更多相关文章

  1. navicat与phpmyadmin做mysql的自定义函数和事件

    自定义函数和事件是mysql一个很方便的功能,navicat在5.1以上版本就支持了自定义函数和事件,phpmyadmim不清楚. 用这个是由于一些简单的事情,没有必要去做一个服务器计划使用 接下来我 ...

  2. JS常用自定义函数总结

    JS常用自定义函数总结   1.原生JavaScript实现字符串长度截取 2.原生JavaScript获取域名主机 3.原生JavaScript清除空格 4.原生JavaScript替换全部 5.原 ...

  3. Mysql - 存储过程/自定义函数

    在数据库操作中, 尤其是碰到一些复杂一些的系统, 不可避免的, 会用到函数/自定义函数, 或者存储过程. 实际项目中, 自定义函数和存储过程是越少越好, 因为这个东西多了, 也是一个非常难以维护的地方 ...

  4. mysql创建自定义函数与存储过程

    mysql创建自定义函数与存储过程 一 创建自定义函数 在使用mysql的过程中,mysql自带的函数可能不能完成我们的业务需求,这时就需要自定义函数,例如笔者在开发过程中遇到下面这个问题 mysql ...

  5. [转]MySQL常用Json函数和MySQL常用字符串函数

    MySQL常用Json函数:https://www.cnblogs.com/waterystone/p/5626098.html MySQL常用字符串函数:https://www.cnblogs.co ...

  6. MYSQL常用操作函数的封装

    1.mysql常用函数封装文件:mysql.func.php <?php /** * 连接MYSQL函数 * @param string $host * @param string $usern ...

  7. MySQL之MySQL常用的函数方法

    MySQL常用函数 本篇主要总结了一些在使用MySQL数据库中常用的函数,本篇大部分都是以实例作为讲解,如果有什么建议或者意见欢迎前来打扰. limit Select * from table ord ...

  8. MySQL(六) —— 自定义函数

    自定义函数 用户自定义函数(user-defined function, UDF)是一种对MySQL扩展的途径,其用法与内置函数相同. 参数,返回值 创建自定义函数 CREATE FUNCTION f ...

  9. MySQL之自定义函数

    引言 MySQL本身提供了内置函数,这些函数的存在给我们日常的开发和数据操作带来了很大的便利,比如我前面提到过的聚合函数SUM().AVG()以及日期时间函数等等,可是我们总会出现其他的需求:我们需要 ...

随机推荐

  1. wx.onMenuShareTimeline使用注意事项

    我在开发测试过程中,发现使用wx.onMenuShareTimeline无效果,没有显示我定义的图片.title和链接,经过调试发现原因如下: 1.图片大小要大于300pix才能显示 2.这个方法必须 ...

  2. 为革命保护视力 --- 给 Visual Studio 换颜色

    “为革命,保护视力,预防近视,眼保健操开始......” 这个应该是最老版本的眼保健操了,你听过? 一堆废话 且不说上面这个眼保健操到底有木有用,让眼睛放松下还是很有必要的,尤其是现在天天对着不是手机 ...

  3. CSharpGL(37)创建和使用VBO的最佳方式

    CSharpGL(37)创建和使用VBO的最佳方式 开始 近日在OpenGL红宝书上看到这样的讲解. 其核心意思是,在创建VBO时用 glBufferData(GL_ARRAY_BUFFER, len ...

  4. ABP源码分析二十八:ABP.MemoryDB

    这个模块简单,且无实际作用.一般实际项目中都有用数据库做持久化,用了数据库就无法用这个MemoryDB 模块了.原因在于ABP限制了UnitOfWork的类型只能有一个(前文以作介绍),一般用了数据库 ...

  5. ABP源码分析三十五:ABP中动态WebAPI原理解析

    动态WebAPI应该算是ABP中最Magic的功能之一了吧.开发人员无须定义继承自ApiController的类,只须重用Application Service中的类就可以对外提供WebAPI的功能, ...

  6. Atitit. 破解  拦截 绕过 网站 手机 短信 验证码  方式 v2 attilax 总结

    Atitit. 破解  拦截 绕过 网站 手机 短信 验证码  方式 v2 attilax 总结 1. 验证码的前世今生11.1. 第一代验证码 图片验证码11.2. 第二代验证码  用户操作 ,比如 ...

  7. pod Spec管理配置

    pod Spec 为自己的项目添加pod管理功能.前言: 上一篇文章中提到,因为自己在操作的时候遇到很多坑,所在在此做一个记录,同样也希望可以帮到在这个操作上遇到坑的人. 本文将采用配图和加文字的方式 ...

  8. Fiddler--一、HTTP协议简介

    在学习Fiddler之前,最好先学习一下HTTP协议. HTTP协议简介 什么是HTTP协议 超文本传输协议(HTTP)是一种通信协议,它允许将超文本标记语言(HTML)文档从Web服务器传送到客户端 ...

  9. 常用的Webpack配置

    官方文档: http://webpack.github.io/docs/ 1. 安装python2. 安装node.js msi3. npm自动打包在最新的node.js安装包里 被封的包用国内镜像下 ...

  10. 5.如何使主机和虚拟机IP处于同一网段(内网渗透专用)

    先说一下正常流程: 1.打开虚拟机网络设置选项,选择桥接模式(Bridged)[如果是Kali 2.0的话,执行第一步后就OK了(90%)] 2.打开Kali里面的网络设置 3.设置一个ip4或者ip ...