線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:3887
推到 Plurk!
推到 Facebook!

請問如何在SQL語法中將某數值無條件進位到整數位

尚未結案
Becca
一般會員


發表:5
回覆:7
積分:2
註冊:2003-10-16

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-03-04 17:51:27 IP:211.23.xxx.xxx 未訂閱
請問哪位大大知道如何在SQL語法中將計算完成的數值無條件進位到整數位,並將FLOAT轉換成INTEGER 例如: SELECT T01,T02,((T03 T04)/T05) AS T0345 FROM TTT ORDER BY T01,T02 T03=4 T04=6 T05=3 ===> ((T03 T04)/T05)=3.3333 要如何才可將T0345這個欄位改成無條件進位並轉換成INTEGER值==>4
jimmy_wei
高階會員


發表:9
回覆:176
積分:147
註冊:2003-08-28

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-03-04 18:24:26 IP:210.68.xxx.xxx 未訂閱
Becca 你好: SELECT CEIL(2.4) FROM DUAL 給果會等於3 這是ORACLE的方法
huangeider
高階會員


發表:288
回覆:492
積分:231
註冊:2003-02-26

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-03-04 18:39:03 IP:202.145.xxx.xxx 未訂閱
我不知道SQL有沒有ORACLE的CEIL函數,以下的做法是先存到暫存檔中再做處理
//暫存
SELECT ( ((T03 T04)/T05)) AS T0345 INTO #TEMP FROM TTT
//二次處理
SELECT T0345= 
 CASE   WHEN T0345>CAST(T0345 AS INTEGER) THEN
CAST(T0345 AS INTEGER)  1  END FROM #TEMP
//沒跳出SQL時做第二次時得先DROP
DROP TABLE  #TEMP
堅持從洗馬桶做起 Eric
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-03-04 22:36:01 IP:218.32.xxx.xxx 未訂閱
手邊沒有資料庫, 不太確定, 試試 "ceiling" 看看, 確實的用法, 查查 Help1吧.
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-03-05 15:35:38 IP:220.132.xxx.xxx 未訂閱
Hi, 請先說明你的資料庫種類, 若是 sql server 的話, 如 mickey 兄所說, 使用 ceiling 即可, 如,    SELECT T01,T02,ceiling((T03 T04)/T05) AS T0345 FROM TTT ORDER BY T01,T02
Becca
一般會員


發表:5
回覆:7
積分:2
註冊:2003-10-16

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-03-07 14:15:35 IP:211.23.xxx.xxx 未訂閱
我用的資料庫是SQL SERVER, 謝謝各位解說讓我知道該如何使用語法 可是我只能給一位大大得分, 讓我很為難(我很想給每個人分數) 其他沒得到分數的,我真的感到很抱歉!! I'm so sorry~~~~
系統時間:2024-06-26 23:56:26
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!