开发工具与关键技术:Oracle sql * plus PLSQL Developer
作者:唐国铭
撰写时间:2019年03月31日

在做练习过程中总会遇到一些需求是获取某一字段里的某一个字母,无论大小写,这时候如果我们按照平常写法就需要在WHERE条件连接里用到OR(或)的关系关键字进行筛选,这就增加了代码量,而在到单行函数中有一类为大小写控制函数,就完美的解决了这个问题。

例如我们需要获取字段中包含有’c‘字符的字段,不论大小写,这时我们可以使用LOWER 函数把此字段里的所有数据转成小写,这样只要此字段里有c或C都能被匹配到,如下:

postgresql转换大写 plsql大小写转换_postgresql转换大写


而既然有全部转成小写的LOWER函数,就有与之对应的转为大写的函数,这个把所选字段全部转为大写的函数就是UPPER,此函数用法类同与LOWER函数,因为此函数把某一字段都转为了大写,所以在筛选条件里把小写的c该为大写C即可。

而当我们需要将一篇英文文章又或者是要把某一串英文的首字母转为大写时又该如何做呢?这时就引入另一个函数INITCAP,此函数可直接把某一字段里的内容直接转为首字母为大写,如下:

postgresql转换大写 plsql大小写转换_首字母_02


在这里有一个问题就是如果我们在录入字段的时候不小心把本是一个英文单词的在中间加多了一个空格,而导致我们在查询转换出来的时候就会出现一个单变成两个单词的形式,这时我们可以引入一个替换的函数REPLACE把空格替换掉,不过这里使用只是针对于本是一个单词的字段,如下:

postgresql转换大写 plsql大小写转换_首字母_03