1.首先是去除空格在進(jìn)行比較(比如,把姓名中的所有空格去除):
創(chuàng)新互聯(lián)公司成立以來(lái)不斷整合自身及行業(yè)資源、不斷突破觀念以使企業(yè)策略得到完善和成熟,建立了一套“以技術(shù)為基點(diǎn),以客戶(hù)需求中心、市場(chǎng)為導(dǎo)向”的快速反應(yīng)體系。對(duì)公司的主營(yíng)項(xiàng)目,如中高端企業(yè)網(wǎng)站企劃 / 設(shè)計(jì)、行業(yè) / 企業(yè)門(mén)戶(hù)設(shè)計(jì)推廣、行業(yè)門(mén)戶(hù)平臺(tái)運(yùn)營(yíng)、成都APP應(yīng)用開(kāi)發(fā)、手機(jī)網(wǎng)站制作設(shè)計(jì)、微信網(wǎng)站制作、軟件開(kāi)發(fā)、遂寧聯(lián)通機(jī)房等實(shí)行標(biāo)準(zhǔn)化操作,讓客戶(hù)可以直觀的預(yù)知到從創(chuàng)新互聯(lián)公司可以獲得的服務(wù)效果。
Update table_name set xm=replace(xm , ' ') ;
如果要查找哪些記錄含有' ',可用相關(guān)的語(yǔ)句查找。
然后可進(jìn)行比較。
2.但是我們可能會(huì)發(fā)現(xiàn),有些姓名中間或末尾還有類(lèi)似空格的字符沒(méi)被去掉,但它們顯然已經(jīng)不是一般的空格了,那么懷疑是Tab健作怪。于是參照網(wǎng)上說(shuō)的去掉TAB鍵的辦法來(lái)處理,用chr(9)來(lái)替代空格鍵(TAB鍵的ASCII值為9)。先取一條帶有類(lèi)空格字符的記錄來(lái)做實(shí)驗(yàn):
SELECT replace(xm, chr(9) ) from table_name where bh=’xxx’;
用這個(gè)辦法會(huì)去掉一些真正的Tab鍵空格,然后采取批量更新的辦法。
3.但我遇到的情況沒(méi)有這么幸運(yùn),沒(méi)能去掉類(lèi)空格鍵。怎么辦呢?我決定嘗試先取得這個(gè)類(lèi)空格鍵的ASCII碼值,然后再用chr(ASCII碼值)的方法來(lái)處理。
①.取得含類(lèi)空格鍵整個(gè)字符串的長(zhǎng)度 length(),從而確定出類(lèi)空格鍵在字符串中的起始位置、類(lèi)空格鍵的長(zhǎng)度。
②.求出類(lèi)空格鍵的ASCII碼值:ascii(substr(xm,n,m)); n為類(lèi)空格鍵的起始位置;m為長(zhǎng)度。
③.SELECT replace(xm, chr(第②步求得的ASCII碼值) ) from table_name where bh=’xxx’;
問(wèn)題得以解決。但我發(fā)現(xiàn),上述第②步求得的ASCII碼值為41377,這應(yīng)該是一個(gè)漢字的ASCII碼值,看起來(lái)又像空格,于是我懷疑,會(huì)不會(huì)是中文狀態(tài)下的空格鍵、TAB鍵?嘗試之后發(fā)現(xiàn)不是。我又懷疑,是不是全角、半角的區(qū)別?因?yàn)槲覀円话爿斎胱址?,是在半角下輸入的。我按照第一步?.首先是去除空格在進(jìn)行比較……”嘗試,輸入全角下的空格,進(jìn)行查找,結(jié)果驚喜出現(xiàn),原來(lái)所有未剔除掉的類(lèi)空格,是全角狀態(tài)下輸入的空格,并接證實(shí)了全角下輸入的空格,其ASCII碼值為41377。
實(shí)現(xiàn)的方法和詳細(xì)的操作步驟如下:
1、第一步,新建一個(gè)測(cè)試表,見(jiàn)下圖,轉(zhuǎn)到下面的步驟。
2、第二步,執(zhí)行完上面的操作之后,將測(cè)試數(shù)據(jù)插入,見(jiàn)下圖,轉(zhuǎn)到下面的步驟。
3、第三步,執(zhí)行完上面的操作之后,查詢(xún)表中數(shù)據(jù),可以發(fā)現(xiàn)字段中帶“-”字符,見(jiàn)下圖,轉(zhuǎn)到下面的步驟。
4、第四步,執(zhí)行完上面的操作之后,編寫(xiě)sql,把字段中的字符‘-’去掉,代碼見(jiàn)下圖。這樣,就解決了這個(gè)問(wèn)題了。
這個(gè)函數(shù)的功能主要是用于去除給定字符串中重復(fù)的字符串.在使用中需要指定字符串的分隔符.示例:
str := RemoveSameStr('zhang,Zhang,bao,Bao,bao,zhang', ',');
輸出: zhang,Zhang,bao,Bao
--SQL
str varchar2(1000);
currentIndex number;
startIndex number;
endIndex number;
type str_type is table of varchar2(30) index by binary_integer;
arr str_type;
Result varchar2(1000);
begin
-- 空字符串
if oldStr is null then
return('');
end if;
--字符串太長(zhǎng)
if length(oldStr) 1000 then
return(oldStr);
end if;
str := oldStr;
currentIndex := 0;
startIndex := 0;
loop
currentIndex := currentIndex + 1;
endIndex := instr(str, sign, 1, currentIndex);
if (endIndex = 0) then
exit;
end if;
arr(currentIndex) := trim(substr(str,
startIndex + 1,
endIndex - startIndex - 1));
startIndex := endIndex;
end loop;
--取最后一個(gè)字符串:
arr(currentIndex) := substr(str, startIndex + 1, length(str));
--去掉重復(fù)出現(xiàn)的字符串:
for i in 1 .. currentIndex - 1 loop
for j in i + 1 .. currentIndex loop
if arr(i) = arr(j) then
arr(j) := '';
end if;
end loop;
end loop;
str := '';
for i in 1 .. currentIndex loop
if arr(i) is not null then
str := str || sign || arr(i);
--數(shù)組置空:
arr(i) := '';
end if;
end loop;
--去掉前面的標(biāo)識(shí)符:
Result := substr(str, 2, length(str));
return(Result);
end RemoveSameStr;
轉(zhuǎn)載,僅供參考。