全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:5928
推到 Plurk!
推到 Facebook!

大小寫問題

缺席
titans
一般會員


發表:5
回覆:0
積分:1
註冊:2007-10-07

發送簡訊給我
#1 引用回覆 回覆 發表時間:2009-04-25 12:34:53 IP:210.6.xxx.xxx 訂閱
我是用ibexpert 及 firebird 1.5,
怎樣才可以將全大寫的英文名字, 變為只有每頭一個字為大寫其餘為小寫?
例如: CHAN TAI MAN 變為 Chan Tai Man
st33chen
尊榮會員


發表:15
回覆:591
積分:1201
註冊:2005-09-30

發送簡訊給我
#2 引用回覆 回覆 發表時間:2009-05-12 13:42:27 IP:122.116.xxx.xxx 未訂閱
您好,
若要下 sql 命令就得到結果, 那最好先寫 stored procedure
例如 :
create procedure capitalize(str varchar(100)) returns (ret varchar(100)) as
declare variable ii integer;
declare variable tstr varchar(100);
begin
tstr = lower(str);
tstr = upper(substr(tstr,1,1)) || substr(tstr,2); <-- 我忘了字串相加可否用 || 還是一定要用 concat
ii = strpos(tstr, ' ');
ret = '';
while (ii>0) do begin
ret = substr(tstr,1,ii) || upper(substr(tstr,ii 1,1)); <-- 我忘了字串相加可否用 || 還是一定要用 concat
tstr = substr(tstr,ii 2);
ii = strpos(tstr, ' ');
end;
ret = ret || tstr;
end;

然後就可以用
select capitalize(your_field_name), ... from ....

若要在 client 程式中取出 db 資料後再處理
那就是操作字串把他改成您要的樣子.
方法很多, 類似上面的 procedure 內容就是一個例子.

我沒實測, 請自行測試修改

參考一下



------
IS IT WHAT IT IS
我是 李慕白 請倒著唸.
又想把老話拿出來說, 請用台語發音 : 專家專家全是ROBOT CAR (滷肉腳啦);
都已接手這麼久了, 績效還是那麼爛, 講話還那麼大聲.
編輯記錄
st33chen 重新編輯於 2009-05-12 13:46:18, 註解 無‧
P.D.
版主


發表:603
回覆:4038
積分:3874
註冊:2006-10-31

發送簡訊給我
#3 引用回覆 回覆 發表時間:2009-06-03 16:17:34 IP:61.67.xxx.xxx 未訂閱
自已開發一個UDF 函式引用
UDF 如何做
1.原則上利用DELPHI 寫一支 DLL 檔
2.FB 中參考 FB 提供的 UDF 語法, 把這支DLL加進來(給客戶時, 這支DLL要隨同附上)
系統時間:2024-11-21 17:09:09
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!