Oracle常用字符函数实验分析
这篇文章主要介绍"Oracle常用字符函数实验分析",在日常操作中,相信很多人在Oracle常用字符函数实验分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Oracle常用字符函数实验分析"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
1.实验预备动作
1)创建实验表T
sec@ora10g> create table t (first_name varchar2(15), family_name varchar2(15), alias_name varchar2(15), mark varchar2(15), ascii_num int);
Table created.
2)初始化一条数据
sec@ora10g> insert into t values ('Secooler ', 'HOU', 'sec', 'H', 72);
1 row created.
sec@ora10g> commit;
Commit complete.
sec@ora10g> select * from t;
FIRST_NAME FAMILY_NAME ALIAS_NAME MARK ASCII_NUM
--------------- --------------- --------------- --------------- ----------
Secooler HOU sec H 72
2.CHR函数
CHR函数可以得到数值对应的字符。因为我们采用的是ASCII字符集,所以数字"72"对应的字符便是"H"。
sec@ora10g> select chr(ASCII_NUM) chr from t;
CHR
----
H
不得不提的ASCII函数,这个函数可以理解是CHR函数的"反函数",通过ASCII函数可以得到字符的ASCII字符编码。
sec@ora10g> select ascii('H') ascii from t;
ASCII
----------
72
sec@ora10g> select ascii(mark) ascii from t;
ASCII
----------
72
3.CONCAT函数
CONCAT函数与"||"符号的功能类似,就是将两个字符串联起来。
sec@ora10g> select concat(FIRST_NAME,FAMILY_NAME) "My Name is" from t;
My Name is
------------------------------
Secooler HOU
使用"||"可以实现同样的效果
sec@ora10g> select FIRST_NAME||FAMILY_NAME "My Name is" from t;
My Name is
------------------------------
Secooler HOU
4.INITCAP函数
INITCAP函数从字面上就可以知道他的功能,即将字符串的第一个字母转换为大写字母,其余部分转换为小写字母的形式。无论字符串初始内容是大写还是小写,都会被转换为统一的形式。
sec@ora10g> select initcap(FIRST_NAME) initcap, initcap(FAMILY_NAME) initcap from t;
INITCAP INITCAP
--------------- ---------------
Secooler Hou
5.LOWER和UPPER函数
LOWER和UPPER函数类似INITCAP函数,只不过这里的LOWER函数会将字符串全部转换为小写字母,UPPER函数将字符串全部转换为大写字母
1)LOWER函数演示
sec@ora10g> select lower(FIRST_NAME) lower, lower(FAMILY_NAME) lower from t;
LOWER LOWER
--------------- ---------------
secooler hou
2)UPPER函数演示
sec@ora10g> select upper(FIRST_NAME) upper, upper(FAMILY_NAME) upper from t;
UPPER UPPER
--------------- ---------------
SECOOLER HOU
6.LPAD和RPAD函数
LPAD和RPAD函数可以完成用特定字符填充字符串到指定长度的目的。
1)在FAMILY_NAME左侧填充"$"符号,使整个字符串的长度为10。
sec@ora10g> select lpad(FAMILY_NAME,10,'$') lpad from t;
LPAD
----------------------------------------
$$$$$$$HOU
2)在FAMILY_NAME右侧填充"$"符号,使整个字符串的长度为10。
sec@ora10g> select rpad(FAMILY_NAME,10,'$') rpad from t;
RPAD
----------------------------------------
HOU$$$$$$$
3)混合使用,在FAMILY_NAME的左侧添加三个"#"符号,同时在其后面添加四个"$"符号。
sec@ora10g> select rpad(lpad(FAMILY_NAME,6,'#'),10,'$') "LPAD and RPAD" from t;
LPAD and RPAD
----------------------------------------
###HOU$$$$
4)如果不指定填充的字符,则默认用空格进行填充
sec@ora10g> select lpad(FAMILY_NAME,10) lpad from t;
LPAD
----------------------------------------
HOU
7.LTRIM和RTRIM函数
LPAD和RPAD函数目的是填充,LTRM和RTRIM函数目的相反,删除对应的内容。
1)删除FIRST_NAME左侧出现的"S"字母
这里为了验证删除"所有"左侧"S"字母,我们再初始化一条前面包含多个S的内容。
sec@ora10g> insert into t(FIRST_NAME) values ('SSSecooler');
1 row created.
sec@ora10g> select FIRST_NAME, ltrim(FIRST_NAME,'S') ltrim from t;
FIRST_NAME LTRIM
--------------- ---------------
Secooler ecooler
SSSecooler ecooler
可见,在FIRST_NAME字段左侧出现的"S"全部被删除了。
2)删除FAMILY_NAME右侧出现的"U"字母
sec@ora10g> select FAMILY_NAME, rtrim(FAMILY_NAME,'U') rtrim from t;
FAMILY_NAME RTRIM
--------------- ---------------
HOU HO
同理,RTRIM函数也是会完成删除"所有"字符的目的。这里不再演示。
3)如果LTRIM和RTRIM函数不使用第二个参数,则实现的功能是去除字符串左侧(LTRIM)或右侧(RTRIM)出现的空格,这是比较常用的基本功能。
到此,关于"Oracle常用字符函数实验分析"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!