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

如何 Select 每個人的前一筆

 
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-03-22 11:50:18 IP:59.124.xxx.xxx 未訂閱
大家好!

table 欄位為 user_id 與 phone_no
每個 user_id 有一支以上的電話號碼
請問一下大家
可否用一句 SQL 語法 Select 出每個 user_id 的第一支電話

謝謝!
bruce
中階會員


發表:19
回覆:121
積分:83
註冊:2002-04-16

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-03-22 12:18:12 IP:203.70.xxx.xxx 訂閱
有困難,無法判定哪一筆才是第一隻電話ㄋㄟ。
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-03-22 12:25:49 IP:59.124.xxx.xxx 未訂閱
感謝 bruce 的指教.

小弟表達不好, 重點不是判斷是不是 "第一支" 電話
而是能 select 出每個 user_id 然後搭配一支電話(若有電話的話)
不知道這樣說會不會太模糊?

謝謝!

暗黑破壞神
版主


發表:9
回覆:2301
積分:1627
註冊:2004-10-04

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-03-22 13:03:57 IP:218.170.xxx.xxx 訂閱
有個叫做 Limit 的。可以加在 select 後面。
那就可以做限制了。
bruce
中階會員


發表:19
回覆:121
積分:83
註冊:2002-04-16

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-03-22 13:26:41 IP:203.70.xxx.xxx 訂閱
從table1 先產生一個不重複的user_id表,指令如下:
select distinct user_id from table1

然後再加上LEFT OUTER JOIN Table1
就可以了,參考看看囉

用一個View來做,一次可以完成的
完整指令參考如下:
select distinct user_id ,table1_1.phone from table1 LEFT OUTER JOIN Table1 _1



Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#6 引用回覆 回覆 發表時間:2007-03-22 15:46:12 IP:59.124.xxx.xxx 未訂閱
SQL Server:
1 Table:
select user_id,min(phone_no) as phone_no from yourtable group by user_id

1 Table with PK:
select * from yourtable where pk in (select min(pk) from yourtable group by user_id)

2 Table:
select distinct user_id,
(select min(phone_no) from yourtab tt where tt.user_id = t.user_id) as mp
from yourtable t



Fishman

------
Fishman
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#7 引用回覆 回覆 發表時間:2007-03-22 15:58:29 IP:59.124.xxx.xxx 未訂閱
感謝暗兄, bruce 與 Fishman 兄的指教!
:-)
系統時間:2024-05-19 20:34:50
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!