首页 / 编程开发 / Mysql对字段内容提取首字母

Mysql对字段内容提取首字母

2017-05-21 14:29:24编程开发 阅读 3364
在一个需求场景中,要实现对标签和专题首字母的索引.在网页上展示A-Z,那么就需要对标题提取首字母。

创建mysql函数


CREATE FUNCTION `fristPinyin`(P_NAME VARCHAR(5000)) RETURNS varchar(255) CHARSET utf8
DETERMINISTIC
BEGIN
    DECLARE V_RETURN VARCHAR(255);
    DECLARE V_BOOL INT DEFAULT 0;
          DECLARE FIRST_VARCHAR VARCHAR(1);

    SET FIRST_VARCHAR = left(CONVERT(P_NAME USING gbk),1);
    SELECT FIRST_VARCHAR REGEXP '[a-zA-Z]' INTO V_BOOL;
    IF V_BOOL = 1 THEN
      SET V_RETURN = FIRST_VARCHAR;
    ELSE
      SET V_RETURN = ELT(INTERVAL(CONV(HEX(left(CONVERT(P_NAME USING gbk),1)),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),
      'A','B','C','D','E','F','G','H','J','K','L','M','N','O','P','Q','R','S','T','W','X','Y','Z');
    END IF;
    RETURN V_RETURN;
END


英文的是小写首字符,汉字的是大写首字母,

select id,name,UPPER(fristPinyin(name)) as first_char from table order by id asc limit 10;


统一换成大写

测试完成后开始给数据创建首字母字段保存,并索引.

添加 first_char字段列

UPDATE table set first_char = UPPER(fristPinyin(name))


本文《Mysql对字段内容提取首字母》由爱思考吧 isres.com 分享,转载请注明出处。本文网址:https://www.isres.com/php/5.html

本站主要收集测评能够节省时间和提升效率的软件工具并分享使用与学习的过程和感受,任何情况下用户都需遵守所使用软件资源的相关协议。与《Mysql对字段内容提取首字母》有关的本站文章及资源仅供个人学习交流使用,相关资源请下载后24小时内删除,请勿用于其它用途,因此产生的任何问题由您自行承担。

猜你喜欢

  • 解决linux rm和软件界面都无法删除的乱码文件名的文件

    解决linux rm和软件界面都无法删除的乱码文件名的文件

    有些看似乱码文件,加一对单引号就能删除。但有些真乱码文件,怎么也删除不掉,用sftp工具连接能看到也删除不掉。 rm: 无法删除"?q???d??": 没有那个文件或目录 这里有一个非常有效果的解决...

    2023-06-04 12:31:08 494
  • PHP导入带图片的word文档转成html并本地化图片

    服务器安装必要的依赖 yum install libreoffice yum install libreoffice-headless 如果出现异常,在页面上不一定表现出来,而是页面卡着一直没响应,...

    2023-04-25 11:51:22 358
  • 用python读取stable diffusion生成的png图片的参数信息

    之前使用stable diffusion生成图片之后,如果要再看绘画参数,需要打开stable diffusion的webui来看图片的参数。 对于其它没安装环境的电脑颇为麻烦。 当然如果要脚本化保...

    2023-06-01 23:05:13 1091
  • 用20行Python代码实现实时获取鼠标屏幕坐标

    用20行Python代码实现实时获取鼠标屏幕坐标

    代码保存为一个py文件,比如xxx.py,再运行这个py文件。 鼠标就会出现一个浮窗跟随,实时显示当前鼠标坐标。 需要先pip install pyautogui import pyautogui ...

    2023-05-08 10:15:24 1447
  • 改版了,换上了自己写程序

    给网站换上了自己开发的PHP代码,想深度定制网站的功能, 原来的typecho熟悉程度不够不想改,wordpress调研了几天也觉得不合适自己之后的深度定制。 评论功能移除了,依靠chatGPT编程...

    2007-04-21 18:23:20 505
  • linux下mysql自动备份脚本,自动清除旧文件防止磁盘满

    linux下mysql自动备份脚本,自动清除旧文件防止磁盘满

    linux环境下的mysql自动备份数据库的shell脚本,默认在运行时自动清理30天前的旧文件,防止一直备份导致磁盘爆满。 加脚本代码保存为一个文件,比如 autoback.sh之后,加入到lin...

    2023-11-08 09:48:39 419
  • Mysql对字段内容提取首字母

    在一个需求场景中,要实现对标签和专题首字母的索引.在网页上展示A-Z,那么就需要对标题提取首字母。 创建mysql函数 CREATE FUNCTION `fristPinyin`(P_NAME VAR...

    2017-05-21 14:29:24 3364
  • C# winform窗体动态创建button按钮并根据文本自动设置宽度

    C# winform窗体动态创建button按钮并根据文本自动设置宽度

    C# winform窗体动态创建button按钮并根据文本自动设置宽度具体功能点为 1、根据xml的项目动态创建tutton 2、每个button的宽度根据按钮上的文本来设置 代码片段如下 // 读...

    2023-09-20 10:23:35 375