select
substr(B,INSTR(B,'【',1,1)+1,INSTR(B,'】',1,1)-INSTR(B,'【',1,1)-1),
from tablename
B表示列名 这个是分割字符串的... 插入你自己做吧
截取字符可以使用字符函数
substr(s1,
m,
n)
参数具体表示:
从字符串s1的第m位起,截取长度为n的子串并返回.m小于0表示从右侧起
举例:
substr('helloword',
-1,
result
from
dual
t;
返回结果为
d
解释:返回字符串右侧第一个字符.
首先便是这Trim函数.Trim 函数具有删除任意指定字符的功能,而去除字符串首尾空格则是trim函数被使用频率最高的一种.语法Trim ( string ) ,参数string:string类型,指定要删除首部和尾部空格的字符串返回值String.函数执行成功时返回删除了string字符串首部和尾部空格的字符串,发生错误时返回空字符串(""). 如果参数值为null时,会抛出空指针异常.在oracle中,trim使用的形式多为人rtrim()与ltrim()两种,分别为去除字符串右边空格与去除字符串左边空格.
当然trim的功能不止如此,下面进行细致的介绍,这里我多以去除字符串空格为例.
我们看下trim函数的语法描述:trim( [ { {leading|trailing|both} [trim_character]|trim_character} from] trim_source
①.)、不使用任何参数
SQL select trim(' 11 ') aa from dual;
AA
--
这是最常见的一种使用方法,都使用默认的参数,默认情况下TRIM会同时删除字符串前后出现的空格.
SQL select trim(both from ' 11 ') aa from dual;
"BOTH"参数表示同时去除字符串前后所指定的内容(默认情况下删除空格).
SQL select trim(leading from ' 11 ') aa from dual;
----
SQL select trim(trailing from ' 11 ') aa from dual;
-----
①.1
从结果中得分隔符'-',可以发现使用leading参数可以去除字符串右端的空格,而trailing参数则可以去除字符串左端的空格.正如oracle提供的rtrim()与ltrim().
trim_character参数改变了"删除空格"的默认行为.如果想要删除字符串'xxxxWORLDxxxx'前后出现的"x","trim_character"参数就派上用场了.
SQL select trim('x' from 'xxxxWORLDxxxx') aaaaa from dual;
AAAAA
WORLD
trim_character配合"both"、"trailing"和"leading"三个参数使用效果如下,与之前演示类似.看结果,不赘述.
SQL select trim(both 'x' from 'xxxxWORLDxxxx') aaaaa from dual;
SQL select trim(trailing 'x' from 'xxxxWORLDxxxx') aaaaa from dual;
---------
xxxxWORLD
SQL select trim(leading 'x' from 'xxxxWORLDxxxx') aaaaa from dual;
WORLDxxxx
必须注意的一点是这里的"trim_character"参数只允许包含一个字符,不支持多字符.trim不能满足我们去除多字符要求,但是我们可以使用rtrim和ltrim来处理.
①.)使用rtrim
SQL select rtrim('ORxxxxWORLDxxxxOR','OR') aaaaa from dual;
---------------
ORxxxxWORLDxxxx
SQL select ltrim('ORxxxxWORLDxxxxOR','OR') aaaaa from dual;
xxxxWORLDxxxxOR
SQL select rtrim(ltrim('ORxxxxWORLDxxxxOR','OR'),'OR') aaaaa from dual;
-------------
xxxxWORLDxxxx
使用rtrim和ltrim函数时的注意事项:"OR"不表示整个"OR"字符串进行匹配,而是发现任意的字符"O"或字符"R"均做删除操作.
'string_replace1' 待搜索的字符串表达式,string_replace1 可以是字符数据或二进制数据.
这里我们依然以去空格为例.
SQL select replace(' aa kk ',' ','') abcd from dual;
ABCD
aakk
与使用trim函数的结果进行对比,我们可以发现,使用replace函数不仅可以去除字符串两端的空格,也可去除字符串内部的空格.
当然,如果只是要去除字符串两端的空格,使用trim函数效率会更高.
(1)定义split_type类型:
--注意下面的inserti语句,varchar类型的值需要补充引号上去
Execute Immediate ' insert into tableName set fieldName = '||T.a ;
Execute Immediate 'commit';
End Loop;
的查询语句,把分开的结果拼成sql语句并写入到表中.
写个存储过程吧,输入参数字符串和分隔符,输出参数TABLE OF NUMBER
查找第一个分隔符,记录当前位置,然后截取之前的部分,添加到输出表
从当前位置下一个字符查找下个分隔符,记录位置,截取数值添加到输出表
继续以上过程,直到遍历整个字符串
,这个字符可以用查找+截取来操作,这种数据为什么扔到数据库里面操作呢?
那你可以用存储过程进行处理了!
oracle
截取字符(substr),检索字符位置(instr)