`
逝去的梦
  • 浏览: 15473 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

sql常用函数instr()和substr()

    博客分类:
  • sql
阅读更多
在Oracle中
可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符。
其语法为:
instr(sourceString,destString,start,appearPosition).  
instr('源字符串' , '目标字符串' ,'开始位置','第几次出现')

其中sourceString代表源字符串;
destString代表想聪源字符串中查找的子串;
start代表查找的开始位置,该参数可选的,默认为1;
appearPosition代表想从源字符中查找出第几次出现的destString,该参数也是可选的,默认为1;


如果start的值为负数,那么代表从右往左进行查找,但是位置数据仍然从左向右计算。
返回值为:查找到的字符串的位置。


对于instr函数,我们经常这样使用:从一个字符串中查找指定子串的位置。例如:
SQL> select instr('yuechaotianyuechao','ao') position from dual;

POSITION
----------
         6
从第7个字符开始搜索
SQL> select instr('yuechaotianyuechao','ao', 7) position from dual;

POSITION
----------
        17
从第1个字符开始,搜索第2次出现子串的位置
SQL> select instr('yuechaotianyuechao','ao', 1, 2) position from dual;

POSITION
----------
        17
注意:1。若‘起始位置’=0 时返回结果为0,
           2。这里只有三个参数,意思是查找第一个要查找字符的位置(因为 ‘第几次出现’默认为1),
当‘起始位置’不大于要查找的第一个字符的位置时,返回的值都将是第一个字符的位置,如果‘起始位置’大于要查找的第一个字符的位置时,返回的值都将是第2个字符的位置,依此类推……(但是也是以第一个字符开始计数)



substr函数的用法,取得字符串中指定起始位置和长度的字符串  ,默认是从起始位置到结束的子串。
substr( string, start_position, [ length ] )      
substr('目标字符串',开始位置,长度)

如:
     substr('This is a test', 6, 2)     would return 'is'
     substr('This is a test', 6)     would return 'is a test'
     substr('TechOnTheNet', -3, 3)     would return 'Net'
     substr('TechOnTheNet', -6, 3)     would return 'The'select substr('Thisisatest', -4, 2) value from dual
-------------------------------------------------------------------------------------------------
关于Instr()和substr()函数-
INSTR共有4个参数;具体格式为:
INSTR(strings|express,strings[,m,[n]])
在一个字符串中搜索指定的字符,返回发现指定的字符的位置;
strings|express 被搜索的字符串
strings 希望搜索的字符串
m 搜索的开始位置,默认为1
n 第n次出现希望搜索的字符串的位置,默认为1

1.被搜索的字符串可以为字符串,也可以为表达式
如:

QUOTE:
SQL> select instr('my 2 firefly','i') result from dual;
RESULT
----------
7
SQL> select instr(initcap('my 2 firefly')||'b','Fi') result from dual;
RESULT
----------
6

2.希望搜索的字符串可以为字符或数字字符,(希望搜索的字符串长度可以1个或多个)
如:

QUOTE:
SQL> select instr('my 2 firefly','i') result from dual;
RESULT
----------
7
SQL> select instr('my 2 firefly','iref') result from dual;
RESULT
----------
7
SQL> select instr('my 2 firefly',2) result from dual;
RESULT
----------
4
SQL> select instr('my 2 firefly',22) result from dual;
RESULT
----------
0

3.m表示要从第几个字符开始查找
如:

QUOTE:
SQL> select instr('my 2 firefly','f',1) result from dual;
RESULT
----------
6
注意:若m=0时返回结果为0
select instr('my 2 firefly','f',0) result from dual;
RESULT
----------
0

注意:这里只有三个参数,意思是查找第一个要查找字符的位置(因为n默认为1),
当m不大于要查找的第一个字符的位置时,返回的值都将是第一个字符的位置,如果m大于要查找的第一个字符的位置时,返回的值都将是第2个字符的位置,依此类推……

如:

QUOTE:
SQL> select instr('my 2 firefly','f',1) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',3) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',6) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',7) result from dual;
RESULT
----------
10
SQL> select instr('my 2 firefly','f',10) result from dual;
RESULT
----------
10

当m大于要查找字符的最大的位置时,返回0

QUOTE:
SQL> select instr('my 2 firefly','f',11) result from dual;
RESULT
----------
0
SQL> select instr('my 2 firefly','f',110) result from dual;
RESULT
----------
0

反之亦然,若m<0,则表示从右向左来查找数据

QUOTE:
SQL> select instr('my 2 firefly','f',-1) result from dual;
RESULT
----------
10
SQL> select instr('my 2 firefly','f',-2) result from dual;
RESULT
----------
10
SQL> select instr('my 2 firefly','f',-4) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',-40) result from dual;
RESULT
----------
0

4.n表示要找第n个该字符
如:

QUOTE:
SQL> select instr('my 2 firefly','f',1,1) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',1,2) result from dual;
RESULT
----------
10
SQL> select instr('my 2 firefly','f',1,3) result from dual;
RESULT
----------
0

当n大于查找源中包含所要查找字符串的最大个数时,返回0
如:

QUOTE:
SQL> select instr('my 2 firefly','f',1,4) result from dual;
RESULT
----------
0
SQL> select instr('my 2 firefly','f',1,40) result from dual;
RESULT
----------
0

当m<0时,表示从右向左查找,如:

QUOTE:
SQL> select instr('my 2 firefly','f',-10,1) result from dual;
RESULT
----------
0
SQL> select instr('my 2 firefly','f',-8,1) result from dual;
RESULT
----------
0
SQL> select instr('my 2 firefly','f',-3,1) result from dual;
RESULT
----------
10

注意:当m不大于要查找的第一个字符的位置时,返回的值都将是第一个字符的位置,如果m大于要查找的第一个字符的位置时,返回的值都将是第2个字符的位置,依此类推……
如:

QUOTE:
SQL> select instr('my 2 firefly','f',-4,1) result from dual;
RESULT
----------
6
等同于:
SQL> select instr('my 2 firefly','f',-1,2) result from dual;
RESULT
----------
6
另注意:如果要查找的字符串为 NULL时,返回NULL
如:
SQL> select instr('my 2 firefly',null,-1,2) result from dual;
RESULT
----------
SQL> select instr('my 2 firefly',null) result from dual;
RESULT
----------
SQL> select instr('my 2 firefly',null,1) result from dual;
RESULT
----------


QUOTE:
================================================

字符串截取函数substr(strings|express,m,[n])
strings|express 被截取的字符串或字符串表达式
m 从第m个字符开始截取
n 截取后字符串长度为n

1.被截取的为字符串或字符串表达式

QUOTE:
SQL> select substr(upper('abcde'),1,2) from dual;
SUBSTR(UPPER('ABCDE'),1,2)
--------------------------
AB
SQL> select substr('abcde',1,2) from dual;
SUBSTR('ABCDE',1,2)
-------------------
ab

2.如果m<0,则表示从右向左截取
这里如果n>0,若n>=|m|,截取字符串长度为|m|个(从右向左截取),
若n<|m|,截取字符串长度为n个(从右向左截取)

如:

QUOTE:
SQL> select substr('abcde',-4,2) from dual;
SUBSTR('ABCDE',-4,2)
--------------------
bc
SQL> select substr('abcde',-4,1) from dual;
SUBSTR('ABCDE',-4,1)
--------------------
b
SQL> select substr('abcde',-4,4) from dual;
SUBSTR('ABCDE',-4,4)
--------------------
bcde
SQL> select substr('abcde',-4,5) from dual;
SUBSTR('ABCDE',-4,5)
--------------------
bcde
SQL> select substr('abcde',-4,50) from dual;
SUBSTR('ABCDE',-4,50)
---------------------
bcde

如果m<0,n=0结果为NULL:

QUOTE:
SQL> select substr('abcde',-4,0) from dual;
SUBSTR('ABCDE',-4,0)
--------------------
SQL> select substr('abcde',-5,0) from dual;
SUBSTR('ABCDE',-5,0)
--------------------

如果m<0,n<0结果为NULL:

QUOTE:
SQL> select substr('abcde',-2,0) from dual;
SUBSTR('ABCDE',-2,0)
--------------------
SQL> select substr('abcde',-2,-1) from dual;
SUBSTR('ABCDE',-2,-1)
---------------------
SQL> select substr('abcde',-2,-4) from dual;
SUBSTR('ABCDE',-2,-4)
---------------------
SQL> select substr('abcde',-3,-4) from dual;
SUBSTR('ABCDE',-3,-4)
---------------------

3.如果n<=0,,结果为0:

QUOTE:
SQL> select substr('abcde',1,-4) from dual;
SUBSTR('ABCDE',1,-4)
--------------------
SQL> select substr('abcde',1,-2) from dual;
SUBSTR('ABCDE',1,-2)
--------------------
SQL> select substr('abcde',1,0) from dual;
SUBSTR('ABCDE',1,0)
-------------------
SQL> select substr('abcde',1,-2) from dual;
SUBSTR('ABCDE',1,-2)
--------------------

4.m,n只要有一个为NULL,那么结果为NULL

QUOTE:
SQL> select substr('abcde',1,null) from dual;
SUBSTR('ABCDE',1,NULL)
----------------------
SQL> select substr('abcde',null,null) from dual;
SUBSTR('ABCDE',NULL,NULL)
-------------------------
SQL> select substr('abcde',null,1) from dual;
SUBSTR('ABCDE',NULL,1)
----------------------

5.不用n参数时:
n=NULL里,结果为NULL
n>=0,结果为从n个字符开始截取到最后


QUOTE:
SQL> select substr('abcde',null) from dual;
SUBSTR('ABCDE',NULL)
--------------------
SQL> select substr('abcde',0) from dual;
SUBSTR('ABCDE',0)
-----------------
abcde
SQL> select substr('abcde',1) from dual;
SUBSTR('ABCDE',1)
-----------------
abcde
SQL> select substr('abcde',2) from dual;
SUBSTR('ABCDE',2)
-----------------
bcde

n<0时,如果|n|<=被截取字符串的长度,
结果为从右向左截取|n|个字符

QUOTE:
SQL> select substr('abcde',-2) from dual;
SUBSTR('ABCDE',-2)
------------------
de
SQL> select substr('abcde',-3) from dual;
SUBSTR('ABCDE',-3)
------------------
cde
SQL> select substr('abcde',-5) from dual;
SUBSTR('ABCDE',-5)
------------------
abcde

如果|n|>被截取字符串的长度,结果为NULL

QUOTE:
SQL> select substr('abcde',-6) from dual;
SUBSTR('ABCDE',-6)
------------------
SQL> select substr('abcde',-60) from dual;
分享到:
评论

相关推荐

    PL/SQL 常用函数

    PL/SQL 常用函数 PL/SQL 中的函数可以分为两大类:单行函数和组函数。单行函数用于处理单行数据,可以在 SELECT、WHERE、ORDER BY 等子句中使用。今天我们将讨论单行函数的使用和规则。 1. 日期格式转换函数 TO_...

    Oracle中instr和substr存储过程详解

    instr和substr存储过程,分析内部大对象的内容 instr函数 instr函数用于从指定的位置开始,从大型对象中查找第N个与模式匹配的字符串。 用于查找内部大对象中的字符串的instr函数语法如下: dbms_lob.instr( lob_...

    SQLServer和Oracle常用函数对比.txt

    ### SQLServer和Oracle常用函数对比 本文将对SQLServer与Oracle数据库系统中常用的数学与字符串处理函数进行详细的对比分析。通过具体的示例和解释,帮助读者更好地理解两种数据库管理系统在处理相似需求时的不同...

    常用的SQL函数详细讲解

    SQL函数在数据库操作中起着至关重要的作用,它们允许我们对数据进行各种处理,包括字符操作、数值计算、日期处理和数据类型转换等。以下是对这些常见SQL函数的详细讲解: 1. **字符函数** - **`UPPER()`**: 这个...

    Oracle函数及常用sql

    本篇文章将深入探讨Oracle中的基本函数以及常用SQL查询,以帮助初学者快速入门,并为日常使用提供参考。 一、Oracle基本函数 1. **字符串函数**: - `CONCAT()`:连接两个或多个字符串。 - `SUBSTR()`:从字符串...

    Oracle_Sql_中常用字符串处理函数

    下面是 Oracle Sql 中常用的字符串处理函数: 1. 大小写转换函数 Oracle Sql 提供了两个大小写转换函数:UPPER() 和 LOWER()。UPPER() 函数将字符串转换为大写,而 LOWER() 函数将字符串转换为小写。 示例:...

    Orace与SQL常用函数对照文档

    ### Orace与SQL常用函数对照知识...以上是Orace与SQL中常用的字符串处理函数及其示例应用,这些函数可以帮助开发人员高效地处理和操作字符串数据。掌握这些函数不仅能够提高查询效率,还能使得数据处理更加灵活和便捷。

    Oracle中的INSTR,NVL和SUBSTR函数的用法详解

    在Oracle数据库中,有三个非常重要的字符串处理函数:INSTR、NVL和SUBSTR。这些函数在处理文本数据时起到至关重要的作用。 1. **INSTR函数**: INSTR函数用于在一个字符串中查找另一个子字符串的位置。其基本语法...

    常用的PL/SQL函数

    ### 常用的PL/SQL函数 #### 引言 在Oracle数据库中,PL/SQL(Procedural Language for SQL)是一种强大的编程语言,它允许开发者编写过程化的SQL代码来处理复杂的数据操作任务。本文将详细介绍Oracle数据库中常用的...

    oracle SQL查询和SQL函数手册 基本涵盖了常用的

    Oracle SQL查询和SQL函数是数据库管理员、开发人员以及数据分析者在处理Oracle数据库时不可或缺的工具。这份手册详尽地介绍了如何有效地使用SQL语言来查询、分析和操作数据,旨在提供全面且实用的知识点。 1. **SQL...

    Oracle sql内置函数大全

    Oracle SQL 中提供了多种内置函数,用于实现各种字符串、数字和日期处理操作。在本文档中,我们将详细介绍这些内置函数,并提供实践示例。 1. ASCII 函数 ASCII 函数用于返回指定字符对应的十进制数。语法为 `...

    Oracle SQL 内置函数以及解析

    以上就是Oracle SQL中一些常用内置函数的详解,这些函数极大地丰富了SQL语言的功能,使得数据查询和处理更加灵活高效。在实际工作中,可以根据需求选择合适的函数,实现对数据的有效操作和分析。

    oracle 和sql Server 函数对比

    本文将深入探讨Oracle与SQL Server在常用函数方面的对比,以便开发者能够更好地理解和选择适合特定场景的函数。 ### 数值函数 1. **长度计算** - Oracle使用`LENGTH`函数,而SQL Server使用`DATALENGTH`函数。 -...

    pl_sql函数大全

    根据提供的文件信息,本文将详细介绍PL/SQL中的一些常用函数及其用法,这些函数对于日常开发工作非常有帮助。 ### 1. ASCII 函数 ASCII 函数用于返回一个字符的 ASCII 值。例如: ``` SQL&gt; SELECT ASCII('A') A, ...

    SQL-67个常用函数

    这里我们将深入探讨67个常用的SQL函数中的一部分,包括字符串处理、字符转换和定位等关键功能。 1. ASCII函数:ASCII函数返回一个字符的ASCII码,即其对应的十进制数字。例如,ASCII('A')返回65,ASCII('a')返回97...

    Oracle SQL 内置函数总结

    Oracle SQL 内置函数是数据库查询和数据处理的重要组成部分,它们极大地增强了SQL语言...通过`Oracle SQL常用函数总结.txt`和`Oracle SQL内置函数总结.sql`文件,你可以找到更多具体的实例和应用场景,进一步加深理解。

    SQLServer和Oracle常用函数对比

    本文将深入探讨SQLServer和Oracle中的常用函数,并进行详细的对比分析。 ### 数学函数 #### 绝对值 - SQLServer使用`ABS()`函数计算数值的绝对值。 - Oracle同样使用`ABS()`函数计算数值的绝对值。例如,`SELECT ...

    oracl常用函数与sql函数对比

    在IT领域,尤其是在数据库管理与...以上总结了Oracle与SQL Server中常用函数的对比及用法,可以看出两者在函数名称和语法上有一定的差异,但在功能上大多相似。理解这些差异有助于在跨平台开发和迁移时更加得心应手。

    SQL Server和Oracle的常用函数对比

    ### SQL Server 和 Oracle 的常用函数对比 在数据库领域中,SQL Server 和 Oracle 是两种非常流行的数据库管理系统。这两种系统虽然有着不同的背景和发展历程,但都提供了丰富的功能来支持数据的存储、管理和查询。...

Global site tag (gtag.js) - Google Analytics