av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

Oracle數(shù)據(jù)庫中的字符處理技巧總結

瀏覽:41日期:2023-11-22 11:51:37

在數(shù)據(jù)庫開發(fā)與維護中,數(shù)據(jù)庫管理員接觸最多的數(shù)據(jù)類型就是字符類型了,包括字符串、日期類型的字符串等等。在Oracle數(shù)據(jù)庫中為了幫助數(shù)據(jù)庫管理員能夠以最快的方式處理這些字符類型的數(shù)據(jù),提供了許多有用的函數(shù)或者工具。筆者今天就談談在Oracle數(shù)據(jù)庫中處理字符串的經驗與心得。

一、去掉尾部的空格字符有時候在查詢或者進行其他處理的時候,需要把字符串尾部的空格字符去掉。如有時候應用軟件設計的不合理,會把空格字符保存在數(shù)據(jù)庫中。如在輸入產品品號的時候,用戶不小心,把“DT001”輸成了“DT001 ”。如果應用程序在設計的時候,能夠自動把尾部的空格去掉然后在保存到數(shù)據(jù)庫中能夠就萬無一失了。但是不少的應用軟件在開發(fā)的時候沒有如此設計。這就給后續(xù)的處理帶來了很多的麻煩。因為利用Where語句來查找記錄的時候,“DT001”(最后不帶空格)與“DT001 ”(最后帶一個空格)兩個是不同的條件。如果想利用這個條件來進行數(shù)據(jù)更新、查詢等等,就會遇到問題。為此在寫相關的Update或者Select語句的時候,可能需要把后面的空格符號去掉。為此在Oracle數(shù)據(jù)庫中,有很多種解決方式。如數(shù)據(jù)庫管理員可以使用Ltrim函數(shù)來實現(xiàn)。這個函數(shù)的格式為Ltrim[c1,c2]。其作用是去掉C1左邊所包含的C2種的任何字符。當遇到不是C2種的字符串時結束,然后返回剩余的字符串。如果把C2字符串設置為空格符號(默認情況下就是空格),那么就可以把DT001后面的空格符號去掉了。二、在頭部自動進行填充有時候可能數(shù)據(jù)庫設計的時候,考慮的不夠周到,導致某些字段不夠大。在對數(shù)據(jù)庫進行升級的時候,需要調整相關的字段。此時就可能需要對某個字段的頭部進行填充,以達到數(shù)據(jù)一致性的要求。如現(xiàn)在有個ERP系統(tǒng),其需要用到一張產品信息的表,其中有一個產品編號字段。剛開始在設計產品編碼的時候,設計的長度不夠,如只設置了5位。隨著企業(yè)產品記錄的增多,需要對這個編碼的內容進行擴展。如產品信息屬于包裝材料類的,需要在原來產品編號的頭部加入一個字符B;如產品信息屬于客供品的,則需要在原來產品編號的頭部加入一個字符C;如產品信息屬于輔助材料的,則在原來的產品編號前面加入一個字符F;等等。此時該如何實現(xiàn)這個需求呢?難道要一個個去修改嗎?現(xiàn)在這手工修改的工作量比較大,而且容易出錯,這個方法不可取。其實在Oracle數(shù)據(jù)庫系統(tǒng)中提供了一個單行字符函數(shù),可以幫助數(shù)據(jù)庫管理員與企業(yè)來解決這個問題。這個函數(shù)就是RPAD函數(shù)。這個命令的格式為RPAD(C1,N,C2)。這個函數(shù)的意識是在C1的右邊填充字符C2,直到字符串的總長度滿足N。默認情況下C2的值為空格,用戶可以根據(jù)自己的需要設置這個值。如果C1的長度比N要大,則會截取C1右邊的N個字符。現(xiàn)在如果要實現(xiàn)上面這個需求,則只需要設置函數(shù)RPAD(產品編號,6,F(xiàn))即可。由于原來的產品編號為5位,現(xiàn)在需要為輔助信息的產品編號前面加入一個字符F,修改后的總長度變?yōu)?位。不過在使用這個函數(shù)的話,往往需要利用Where條件語句進行限制。現(xiàn)在這個函數(shù)還可以里用實現(xiàn)字符串的截取。如還是這個產品編號,其前面一位表示產品的種類。此時數(shù)據(jù)庫管理員就可以利用RPAD(產品編號,1)來截取產品編號的第一位字符(這里產品編號的長度比1要大,則會截取產品右邊的1個字符,即產品類別標示碼)。這在報表設計的時候也非常有用,有利于簡化報表的顯示。三、字符大小寫的控制在做報表的時候,我們可能需要對字符串的現(xiàn)實格式進行控制,如大小寫的顯示格式。另外,在進行數(shù)據(jù)庫移植的時候,可能以前的收入大小寫不規(guī)范。數(shù)據(jù)庫管理員需要采用一定的規(guī)則來規(guī)范移植后的數(shù)據(jù)庫字符串書寫規(guī)范。為了簡化這些需求的實現(xiàn)方式,在Oracle數(shù)據(jù)庫中也提供了一些工具來解決這些問題。如以前在輸入產品編號的時,可能大小寫不區(qū)分。而在前臺應用程序中也沒有進行這方面的控制。現(xiàn)在用戶希望所有的產品編號都為大寫,需要把原先是小寫的產品編號全部轉換成大寫。此時如果產品數(shù)量比較多的話,顯然利用手工修改的方式會增加工作量。如果編寫一個程序來實現(xiàn)的話,又太復雜,其實我們可以借鑒Oracle數(shù)據(jù)庫提供的字符串處理函數(shù)來實現(xiàn)。在單行字符函數(shù)集中,有一個函數(shù)UPPER,它的作用就是將全部字符串都改寫為大寫并返回。為此我們可以利用一個子查詢或者借助視圖的幫助,把所有產品編號中,如果含有小寫字符的產品編號都更新為大寫。如果原來就是大寫的,就保持原樣(而不是說原來大寫的變小寫,原來小寫的變大寫)。同理,既然小寫可以變大寫,那么大寫也就可以變?yōu)樾憽@脝涡凶址瘮?shù)LOWER,就可以把全部字符串改為小寫輸出(把大寫字母改為小寫,而小寫字符保持不變)。另外一個大小寫的控制原則比較復雜,如對于一些英文地址或者英文名字之類的字符串,需要首個字母大寫,而其他字符小寫。這個實現(xiàn)起來就有一定的難度。還好在Oracle數(shù)據(jù)庫中提供了一個現(xiàn)成的解決方法,即利用Initchar函數(shù)來實現(xiàn)。這個函數(shù)的功能是將某個字段中每個單詞的首字符轉換為大小,其他字符都是小寫的字符串。通常情況下,這個字段之間的單詞可以利用空格、控制字符或則標點符號來表示。可見通過這個三個大小寫字符串控制函數(shù),可以優(yōu)化字符串的顯示格式,讓其顯示更加的規(guī)范。而結合Update語句的話,還可以成批的在數(shù)據(jù)庫中進行更新,讓其保存的數(shù)據(jù)也符合規(guī)范化的要求。四、字符串中的復雜替換幾年之后,杭州進行來一些行政區(qū)劃的規(guī)格,如把下沙市改為了直屬杭州管轄的下沙區(qū)。為此有一家企業(yè)的數(shù)據(jù)庫管理人員就問筆者,能否把一些記錄中的下沙市都改為下沙區(qū)。什么意思呢?也就是說,在數(shù)據(jù)庫中可有含有如下記錄“下沙市某某鋼鐵廠”、“杭州市某某服裝廠”、“濱江區(qū)某某信息有限公司”等等。現(xiàn)在數(shù)據(jù)庫管理員希望把含下沙市的內容都改為下沙區(qū)。這涉及到一些復雜字段的替換,實現(xiàn)起來具有一定的難度。數(shù)據(jù)庫是結構化數(shù)據(jù)的結合體,不比Word文檔,可以利用查找替換功能來解決這個需求。那么在Oracle數(shù)據(jù)庫中該如何實現(xiàn)呢?在Oracle數(shù)據(jù)庫中就模擬實現(xiàn)了Word文檔中的查找替換功能。如在單行字符函數(shù)中有一個叫做Replace的函數(shù),就可以幫助數(shù)據(jù)庫管理員實現(xiàn)這個需求。這個函數(shù)的格式為Replace(C1,C2,C3)。他的含義就彪死后把C1中出現(xiàn)的C2都替換成C3,然后返回字符串。這是什么意思呢?其實就是跟Word文檔中的查找替換功能類似。從字符串C1種查找C2的內容,如果找到的話利用C3來代替。如果C3 的內容為空,則所有在字段中出現(xiàn)C2內容的字符都將被刪除。那要實現(xiàn)上面的需求,就可以把這個函數(shù)的參數(shù)設置為Replace(Adress,下沙市,下沙區(qū))。然后再利用Upadate語句把這個函數(shù)返回的值賦值給地址字段即可。如此,在數(shù)據(jù)庫地址字段中,出現(xiàn)下沙市的地方將全部被更新為下沙區(qū)。但是這個更改不會影響到其他的記錄。如不會把杭州市也改為杭州區(qū)等等。為此,要實現(xiàn)一些復雜的字符替換作業(yè),可以利用函數(shù)Replace來完成。有時會,把Replace函數(shù)與其他函數(shù)相結合,還可以實現(xiàn)一些更加復雜的內容。如在產品基本信息中,產品編號中可能包含了產品的分類信息,如PSD001這個產品編號,第一個字符P表示成批,第二三個字符SD表示手動工具。如果自動工具的話就為PZD001。在生成報表的時候,如果利用這些字符來顯示結果的話,顯然報表的可讀性并不是很好。此時數(shù)據(jù)庫管理員可以先利用字符串截取函數(shù)或者利用上面所提到過的頭部填充函數(shù)等等來截取相關的字符串,然后再利用現(xiàn)在這個查找替換函數(shù),則可以把ZD等字符轉換成“自動工具”等代表含義的字符串,這將提高報表的可讀性。可見,將Replace替換函數(shù)與其他函數(shù)結合(C1、C2、C3參數(shù)都可以利用函數(shù)來實現(xiàn))從而可以實現(xiàn)復雜的替換功能。

主站蜘蛛池模板: 亚洲成人三级 | 久久中文字幕一区 | 国产日韩欧美在线观看 | 亚洲精品福利在线 | a视频在线| 亚洲性视频| 成人a免费 | 欧美日韩亚 | 久久成人精品视频 | 日韩免费视频一区二区 | 日本久草 | 免费观看日韩精品 | 一区二区在线不卡 | 一区二区三区在线播放视频 | 国产精品自拍视频网站 | 91偷拍精品一区二区三区 | 欧美一区二区 | 婷婷色国产偷v国产偷v小说 | 亚洲成人一区二区 | 久久国产亚洲 | 日日夜夜91| 成人精品视频免费 | 伊伊综合网 | 精品国产乱码久久久久久闺蜜 | 先锋资源在线 | 色偷偷888欧美精品久久久 | 国内91在线 | 国产色 | 欧美日韩国产精品一区二区 | 羞羞涩涩在线观看 | 黄色免费在线网址 | 欧美性生活一区二区三区 | 五月婷婷亚洲 | 亚洲欧美激情四射 | 亚洲一区综合 | 日本一区二区视频 | 日韩精品在线观看视频 | 美国av片在线观看 | 久久久蜜臀国产一区二区 | 久久久久久久久久久久一区二区 | 日韩中文字幕免费 |