MySQL有的时候需要用到类似lastIndexOf
的功能,然而它没有现成直接可用的函数,就需要自己来琢磨了。
首先,MySQL提供了以下3个函数:
- instr(str:varchar, substr:varchar):返回subsrtr在str第一次出现的位置
# 例如:在字符串ab/cd/abc.html中查找b第一次出现的位置
select instr('ab/cd/abc.html', 'b');
# 跟程序员想的不同的是,上面的结果是 2 (下标从1开始,需要注意一下)
- reverse(str:varchar):首尾反转字符串,输入abc则输出cba
- length(str:varcha):返回字符串长度
知道了以上的信息后我想大部分的人都知道怎么做lastInfdexOf
的功能了。
直接给出:
select length('输入的字符串') - instr(reverse('输入的字符串'), '需要查找的字符串');
# e.g 查找‘/’在字符串'ab/cd/abc.html'中的最后位置。下面的结果为:5
select length('ab/cd/abc.html') - instr(reverse('ab/cd/abc.html'), '/');
最后给出一个最近遇到的一个小需求:
编写sql脚本,取出数据库字段的值(值是文件的路径名,例如ab/cd/abc.html)并解析出文件名(abc.html):
select right(CONTENT_NAME, instr(reverse(CONTENT_NAME), '/') - 1) FILE_NAME
from config_template_content
where lower(CONTENT_NAME) like '%/%.html';
# 当数据都是含有/的时候这么处理就够了,如果存在字段值为 abcde.html 的时候就要加判断咯~
上面用到了right函数,请自行搜索 (体会)其用处