Oracle函数3—内容截取(substr、instr )

准备数据

CREATE TABLE GradesTable (Name VARCHAR2(6), Languages VARCHAR2(6),Mathematics VARCHAR2(6), English VARCHAR2(6) );
insert into GradesTable (Name,Languages,Mathematics,English) values('李明','88','67','98');
insert into GradesTable (Name,Languages,Mathematics,English) values('阿珂','88','67','98');
insert into GradesTable (Name,Languages,Mathematics,English) values('唐三','88','67','98');

1、substr

截取字符串

(1)语法:SUBSTR(string,start, [length])

(2)含义

  • string:表示源字符串,即要截取的字符串

  • start:开始位置,从第1位置查找,如果start是负数,则从字符串末尾开始

  • length:可选项,表示截取字符串长度

(3)举例

截取name为李明的第一位

select substr(name,0,1) from GradesTable where name='李明';--执行结果:李

2、instr

返回子字符串在源字符串中的位置

(1)语法:INSTR(string,child_string,[start],[show_time])

(2)含义

  • string:表示源字符串。
  • child_string:子字符串,即要查找的字符串。
  • start:可选项,开始位置,默认从1开始。如果为负数,则从右向左检索。
  • show_time:可选项,表示子字符串第几次出现在源字符串当中,默认第1次,负数则报错。

(3)举例

从源字符串’abcdefghijklmnj’中第1个字符开始查找子字符串’j’第2次出现的位置

SELECT INSTR('abcdefghijklmnj', 'j', 1, 2) FROM dual    --返回15
  • 3
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值