Oracle数据库中的字符串处理技巧(1)
二、在头部自动进行填充。
有时候可能数据库设计的时候,考虑的不够周到,导致某些字段不够大。在对数据库进行升级的时候,需要调整相干的字段。此时就可能需要对某个字段的头部进行填充,以达到数据一致性的要求。如现在有个ERP系统,其须要用到一张产品信息的表,其中有一个产品编号字段。刚开始在设计产品编码的时候,设计的长度不够,如只设置了5位。随着企业产品记录的增多,需要对这个编码的内容进行扩展。如产品信息属于包装材料类的,须要在原来产品编号的头部加入一个字符B;如产品信息属于客供品的,则须要在原来产品编号的头部加入一个字符C;如产品信息属于辅助材料的,则在本来的产品编号前面加入一个字符F;等等。
此时该如何实现这个需求呢?难道要一个个去修改吗?现在这手工修改的工作量比较大,而且容易出错,这个方法不可取。其实在Oracle数据库系统中提供了一个单行字符函数,可以帮助数据库管理员与企业来解决这个问题。这个函数就是RPAD函数。这个命令的格式为RPAD(C1,N,C2)。这个函数的意识是在C1的右边填充字符C2,直到字符串的总长度满足N。默认状况下C2的值为空格,用户可以依据自己的须要设置这个值。如果C1的长度比N要大,则会截取C1右边的N个字符。现在如果要实现上面这个需求,则只须要设置函数RPAD(产品编号,6,F)即可。由于原来的产品编号为5位,现在需要为辅助信息的产品编号前面加入一个字符F,修改后的总长度变为6位。不过在使用这个函数的话,往往须要利用Where条件语句进行限制。
现在这个函数还可以里用实现字符串的截取。如还是这个产品编号,其前面一位表示产品的种类。此时数据库管理员就可以利用RPAD(产品编号,1)来截取产品编号的第一位字符(这里产品编号的长度比1要大,则会截取产品右边的1个字符,即产品类别标示码)。这在报表设计的时候也非常有用,有利于简化报表的显示。
三、字符大小写的操纵。
在做报表的时候,我们可能须要对字符串的现实格式进行操纵,如大小写的显示格式。另外,在进行数据库移植的时候,可能以前的收入大小写不规范。
数据库管理员须要采用一定的规则来规范移植后的数据库字符串书写规范。为了简化这些需求的实现方式,在Oracle数据库中也提供了一些工具来解决这些问题。
如以前在输入产品编号的时,可能大小写不区分。而在前台应用程序中也没有进行这方面的操纵。现在用户希望所有的产品编号都为大写,须要把原先是小写的产品编号全部转换成大写。此时如果产品数量比较多的话,显然利用手工修改的方式会增加工作量。如果编写一个程序来实现的话,又太复杂,其实我们可以借鉴Oracle数据库提供的字符串处理函数来实现。
在单行字符函数集中,有一个函数UPPER,它的作用就是将全部字符串都改写为大写并返回。为此我们可以利用一个子查询或者借助视图的帮助,把所有产品编号中,要是含有小写字符的产品编号都更新为大写。要是本来就是大写的,就保持原样(而不是说本来大写的变小写,原来小写的变大写)。同理,既然小写可以变大写,那么大写也就可以变为小写。利用单行字符串函数LOWER,就可以把全部字符串改为小写输出(把大写字母改为小写,而小写字符保持不变)。
另外一个大小写的控制原则比较复杂,如对于一些英文地址或者英文名字之类的字符串,须要首个字母大写,而其他字符小写。这个实现起来就有一定的难度。还好在Oracle数据库中提供了一个现成的解决方法,即利用Initchar函数来实现。
这个函数的功能是将某个字段中每个单词的首字符转换为大小,其他字符都是小写的字符串。通常情况下,这个字段之间的单词可以利用空格、控制字符或则标点符号来表示。可见通过这个三个大小写字符串控制函数,可以优化字符串的显示格式,让其显示越发的规范。而结合Update语句的话,还可以成批的在数据库中进行更新,让其保存的数据也符合规范化的要求。
四、字符串中的复杂替换。
几年之后,杭州进行来一些行政区划的规格,如把下沙市改为了直属杭州管辖的下沙区。为此有一家企业的数据库管理人员就问笔者,能否把一些记录中的下沙市都改为下沙区。什么意思呢?也就是说,在数据库中可有含有如下记录“下沙市某某钢铁厂”、“杭州市某某服装厂”、“滨江区某某信息有限公司”等等。
现在数据库管理员希望把含下沙市的内容都改为下沙区。这涉及到一些复杂字段的替换,实现起来具有一定的难度。数据库是结构化数据的结合体,不比Word文档,可以利用查找替换功能来解决这个需求。那么在Oracle数据库中该如何实现呢?在Oracle数据库中就模拟实现了Word文档中的查找替换功能。
如在单行字符函数中有一个叫做Replace的函数,就可以帮助数据库管理员实现这个需求。这个函数的格式为Replace(C1,C2,C3)。他的含义就彪死后把C1中出现的C2都替换成C3,然后返回字符串。这是什么意思呢?其实就是跟Word文档中的查找替换功能类似。
从字符串C1种查找C2的内容,要是找到的话利用C3来代替。要是C3的内容为空,则所有在字段中出现C2内容的字符都将被删除。那要实现上面的需求,就可以把这个函数的参数设置为Replace(Adress,下沙市,下沙区)。然后再利用Upadate语句把这个函数返回的值赋值给地址字段即可。如此,在数据库地址字段中,出现下沙市的地方将全部被更新为下沙区。可是这个更改不会影响到其他的记录。如不会把杭州市也改为杭州区等等。
为此,要实现一些复杂的字符替换作业,可以利用函数Replace来完成。有时会,把Replace函数与其他函数相结合,还可以实现一些更加复杂的内容。
- 1
- 2
