博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
今天做首字母查询功能时调用的一个函数
阅读量:6847 次
发布时间:2019-06-26

本文共 1197 字,大约阅读时间需要 3 分钟。

#首字母查询的数据库函数DELIMITER $$USE `medical`$$DROP FUNCTION IF EXISTS `getInitials`$$CREATE FUNCTION `getInitials`(in_string VARCHAR(100)) RETURNS VARCHAR(100) CHARSET utf8BEGIN#定义临时字符串变量,用于接收函数中传递进来的字符串值,这里是in_stringDECLARE tmp_str VARCHAR(100) CHARSET gbk DEFAULT '' ; #定义临时字符串变量,用于存放函数中传递进来的字符串值的第一个字符DECLARE tmp_char VARCHAR(2) CHARSET gbk DEFAULT '';#tmp_str的长度DECLARE tmp_loc SMALLINT DEFAULT 0;#初始化,将in_string赋给tmp_strSET tmp_str = in_string;#获取tmp_str最左端的首个字符,注意这里是获取首个字符,该字符可能是汉字,也可能不是。SET tmp_char = LEFT(tmp_str,1);#获取字符的编码范围的位置,为了确认汉字拼音首字母是那一个SET tmp_loc=INTERVAL(CONV(HEX(tmp_char),16,10),0xB0A1,0xB0C5,0xB2C1,0xB4EE,0xB6EA,0xB7A2,0xB8C1,0xB9FE,0xBBF7,0xBFA6,0xC0AC,0xC2E8,0xC4C3,0xC5B6,0xC5BE,0xC6DA,0xC8BB,0xC8F6,0xCBFA,0xCDDA ,0xCEF4,0xD1B9,0xD4D1);#判断左端首个字符是多字节还是单字节字符,要是多字节则认为是汉字且作以下拼音获取,要是单字节则不处理。如果是多字节字符但是不在对应的编码范围之内,即对应的不是大写字母则也不做处理,这样数字或者特殊字符就保持原样了IF (LENGTH(tmp_char)>1 AND tmp_loc>0 AND tmp_loc<24) THENSELECT ELT(tmp_loc,'A','B','C','D','E','F','G','H','J','K','L','M','N','O','P','Q','R','S','T','W','X','Y','Z') INTO tmp_char; #获得汉字拼音首字符END IF;RETURN tmp_char;#返回汉字拼音首字符END$$DELIMITER ;

通过getInitials(string)方法获取函数首字母。

转载于:https://www.cnblogs.com/lifan565230673/p/9714369.html

你可能感兴趣的文章
git 删除远程分支文件夹
查看>>
常用单词1
查看>>
angular 的 GET 请求 和 POST 请求的 区别 及 实现
查看>>
C# 如何在Excel表格中插入、编辑和删除批注
查看>>
基于微服务的电商系统架构
查看>>
用户管理及授权管理
查看>>
mysql 配置MHA
查看>>
Windows Developer Day - MSIX and Advanced Installer
查看>>
【tp5】ThinkCMF5框架,配置使其支持不同终端PC/WAP/Wechat能加载不同配置和视图
查看>>
spring security+freemarker获取登陆用户的信息
查看>>
[RxJS] Implement RxJS `concatMap` by Waiting for Inner Subscriptions to Complete
查看>>
ubuntu创建idea桌面快捷方式
查看>>
详解JNDI的lookup资源引用java:/comp/env
查看>>
如何在IntelliJ IDEA中使用Git .ignore插件忽略不必要提交的文件
查看>>
愿你走出半生,归来仍是Java Parser
查看>>
C# 获取接口数据(xml格式)转为json格式
查看>>
asp.net mvc session锁问题 (转载)
查看>>
[转]决定人生的三种成本:机会成本,沉没成本,边际成本
查看>>
A Generic Particle IO Library
查看>>
Enterprise Library 系列教程
查看>>