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

請教各位先進一個 SELECT SQL 的問題!...

答題得分者是:Mickey
Tomas.Chen
一般會員


發表:5
回覆:6
積分:2
註冊:2003-11-02

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-03-21 21:28:56 IP:220.139.xxx.xxx 未訂閱
請教各位先進一個 Update SQL 的問題!... 我有一個 Table1 ,欄位如下: ------------------ Name(姓名) 字串欄位 Sex(性別) 字串欄位 '男' or '女' Score(分數) 數字欄位 Bonus(獎勵) 數字欄位 ------------------ 當我想利用 SELECT 的方式來取得 Sex='女'的人中 Bonus(獎勵)最高者為多少,我的 SQL 語法是這樣下的: SELECT max(Bonus) from Table1 where Sex='女' 但是我發現一個問題,當符合 where 條件的資料不存在(也就是說資料表中根本沒有女的),所得到的max of Bonus 固然為空白,但很遺憾地這個SQL的 RecordCount 卻是=1,請問要如何才可以讓當符合where 條件的資料不存在時,RecordCount 能夠顯示為 0 呢? 再此先行謝過啦!...
Mickey
版主


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-03-21 22:19:22 IP:218.32.xxx.xxx 未訂閱
Tomas.Chen 你好: 試試看: SELECT max(Bonus) from Table1 where Sex='女' having max(Bonus) is not null
Tomas.Chen
一般會員


發表:5
回覆:6
積分:2
註冊:2003-11-02

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-03-21 23:21:02 IP:220.139.xxx.xxx 未訂閱
嗯!OK了!... 謝謝
timhuang
尊榮會員


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

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-03-21 23:26:12 IP:61.62.xxx.xxx 未訂閱
Hi, 考慮多人可能同時會有最高的 bonus 時, 可以改這樣下: select count(*) from table1 where bonus = (select max(bonus) from table1 where sex='女' having max(bonus) is not null) 這樣若是沒有符合條件的資料時, select 回來的 count 就會是 0, 若是有多筆皆為最大值時, select 回來的 count 即為筆數!
系統時間:2024-05-19 5:14:56
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!