#参考这篇博客:http://blog.csdn.net/naruto1021/article/details/17502783,不过这个只支持查询一个中文字母,这是不太符合我的要求,改写如下:
如果要实现查询名字的完整,请参考如下我的程序:
# 查询中文拼音首字母: 支持查询三个中文以内中文,比如 ”张三枫“,输入‘zs’,就可以查询出来
select name,get_first_pinyin_char(name) from retire_infor re
where get_first_pinyin_char(re.name) = 'zs' ;
#首先创建如下函数:支持查询三个中文以内的首字母
BEGIN
DECLARE V_RETURN VARCHAR(255);
DECLARE V_RETURN_TWO VARCHAR(255);
DECLARE V_RETURN_THREE VARCHAR(255);
DECLARE V_FIRST_CHAR VARCHAR(2);
DECLARE V_TWO_CHAR VARCHAR(2);
DECLARE V_THREE_CHAR VARCHAR(2);
#第一个中文首字母匹配
SET V_FIRST_CHAR = UPPER(LEFT(PARAM,1));
SET V_RETURN = V_FIRST_CHAR;
IF LENGTH( V_FIRST_CHAR) <> CHARACTER_LENGTH( V_FIRST_CHAR ) THEN
SET V_RETURN = ELT(INTERVAL(CONV(HEX(LEFT(CONVERT(PARA