猿问

select语句 instr函数与substr函数的综合问题?

语句如下
select 
filename || '|' || substr(filename, 0, instr(filename, '.', -1) - 1) || '.pdf' as filename,
filepath || '|' || substr(filepath, 0, instr(filepath, '.', -1) - 1) || '.pdf' as filepath,
lower(substr(filepath, instr(filepath, '.', -1) + 1)) || ',pdf' as filetype
from ...
问题:太综合了,虽然单个的函数instr与substr都知道as俺也是懂点,但我现在有点晕呀,哪位大侠帮忙解释一下呢?已经人工分成三行啦,具体帮忙解释下,若是有例子那就完美了 。谢谢你们了

精慕HU
浏览 864回答 2
2回答

慕无忌1623718

你都懂,具体的意思我就不解释了就举一个列子filename || '|' || substr(filename, 0, instr(filename, '.', -1) - 1) || '.pdf' as filename,这个吧原始数据namea123452.2Select Name || '|' || substr(Name, 0, instr(Name, '.', -1) - 1) || '.pdf' as filename From user1结果filenamea123452.2|a123452.pdf其实不是很复杂 ||是连接的a123452.2吧后面的结果用||连接起来了 ,后面的.pdf是字符串lower函数是把大写转成小写

HUWWW

既然函数的含义和用法你都清楚,我就说说这个语句的总体含义,分别给你解释一下:filename:这个值是根据查出的filename 去掉"."以及后面的字符,假如表中filename = 记事本1.txt,那么最后filename的值为:记事本|记事本.pdffilepath:和上一个一样,假如filepath = C:\program files\记事本1.txt,那么最后filepath的值为:C:\program files\记事本1.pdffiletype:取的是文件扩展名,假如filepath = C:\program files\记事本1.txt,那么最后filetype的值为小写的txt,pdf
随时随地看视频慕课网APP

相关分类

Oracle
我要回答