PL/SQL单行字符串函数

本文深入探讨了SQL中用于操作字符串的单行函数,包括ASCII、CHR、CONCAT、INITCAP、INSTR、LENGTH、lower、LPAD、LTRIM、RPAD、RTRIM、REPLACE、SUBSTR、UPPER等,并通过示例展示了它们的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

单行字符串函数用于操作字符串数据,他们大多数有一个或多个参数,其中绝大多数返回字符串

  ASCII()
  c1是一字符串,返回c1第一个字母的ASCII码,他的逆函数是CHR()

SELECT ASCII('A') BIG_A,ASCII('z') BIG_z FROM emp

BIG_A BIG_z
65 122


  CHR(<i>)[NCHAR_CS]
  i是一个数字,函数返回十进制表示的字符

select CHR(65),CHR(122),CHR(66) FROM dual

CHR65 CHR122 CHR66

A z B


  CONCAT(,)
  c1,c2均为字符串,函数将c2连接到c1的后面,如果c1为null,将返回c2.如果c2为null,则返回c1,如果c1、c2都为null,则返回null。他和操作符||返回的结果相同

select concat('slobo ','Svoboda') username from dual

username

slobo Syoboda


  INITCAP()
  c1为一字符串。函数将每个单词的第一个字母大写其它字母小写返回。单词由空格,控制字符,标点符号限制。

select INITCAP('veni,vedi,vici') Ceasar from dual

Ceasar

Veni,Vedi,Vici


  INSTR(,[,<i>[,]])
  c1,c2均为字符串,i,j为整数。函数返回c2在c1中第j次出现的位置,搜索从c1的第i个字符开始。当没有发现需要的字符时返回0,如果i为负数,那么搜索将从右到左进行,但是位置的计算还是从左到右,i和j的缺省值为1.

select INSTR('Mississippi','i',3,3) from dual

INSTR('MISSISSIPPI','I',3,3)

11

select INSTR('Mississippi','i',-2,3) from dual

INSTR('MISSISSIPPI','I',3,3)

2


  INSTRB(,[,i[,j])
  与INSTR()函数一样,只是他返回的是字节,对于单字节INSTRB()等于INSTR()

  LENGTH()
  c1为字符串,返回c1的长度,如果c1为null,那么将返回null值。

select LENGTH('Ipso Facto') ergo from dual

ergo

10


  LENGTHb()
  与LENGTH()一样,返回字节。

  lower()
  返回c的小写字符,经常出现在where子串中

select LOWER(colorname) from itemdetail WHERE LOWER(colorname) LIKE '%white%'

COLORNAME

winterwhite


  LPAD(,<i>[,])
  c1,c2均为字符串,i为整数。在c1的左侧用c2字符串补足致长度i,可多次重复,如果i小于c1的长度,那么只返回i那么长的c1字符,其他的将被截去。c2的缺省值为单空格,参见RPAD。

select LPAD(answer,7,'') padded,answer unpadded from question;

PADDED UNPADDED

Yes Yes
NO NO
Maybe maybe


  LTRIM(,)
  把c1中最左边的字符去掉,使其第一个字符不在c2中,如果没有c2,那么c1就不会改变。

select LTRIM('Mississippi','Mis') from dual

LTR

ppi


  RPAD(,<i>[,])
  在c1的右侧用c2字符串补足致长度i,可多次重复,如果i小于c1的长度,那么只返回i那么长的c1字符,其他的将被截去。c2的缺省值为单空格,其他与LPAD相似

  RTRIM(,)
  把c1中最右边的字符去掉,使其第后一个字符不在c2中,如果没有c2,那么c1就不会改变。

  REPLACE(,[,])
  c1,c2,c3都是字符串,函数用c3代替出现在c1中的c2后返回。

select REPLACE('uptown','up','down') from dual

REPLACE

downtown


  STBSTR(,<i>[,])
  c1为一字符串,i,j为整数,从c1的第i位开始返回长度为j的子字符串,如果j为空,则直到串的尾部。

select SUBSTR('Message',1,4) from dual

SUBS

Mess


  SUBSTRB(,<i>[,])
  与SUBSTR大致相同,只是I,J是以字节计算。

  SOUNDEX()
  返回与c1发音相似的词

select SOUNDEX('dawes') Dawes SOUNDEX('daws') Daws, SOUNDEX('dawson') from dual

Dawes Daws Dawson

D200 D200 D250


  TRANSLATE(,,)
  将c1中与c2相同的字符以c3代替

select TRANSLATE('fumble','uf','ar') test from dual

TEXT

ramble


  TRIM([[]] from c3)
  将c3串中的第一个,最后一个,或者都删除。

select TRIM(' space padded ') trim from dual

TRIM

space padded


  UPPER()
  返回c1的大写,常出现where子串中

select name from dual where UPPER(name) LIKE 'KI%'

NAME

KING

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值