作者KC73 (肯先生)
看板Database
标题Re: [SQL ] 对同一个TABLE重覆Query, 浪费时间@@
时间Mon Sep 10 18:37:50 2007
※ 引述《wildpeanut (B级的人生)》之铭言:
: 各位好
: 我有一个table连结的问题(不同於上次那个...)如下
: LOGIN_HISTORY
: ID TIME IP NAME PHONE ADDRESS
: -- ---- -- ---- ----- -------
: 01 07/02/11 1.1.1.1 AA 001 AB-T
: 01 07/03/22 2.1.2.1 AA 001 AB-T
: 02 07/04/01 3.2.3.1 CC 312 MG-R
: 02 07/05/04 5.4.3.1 CC 312 MG-R
: 03 07/06/05 1.3.1.8 DD 918 CP-N
: 03 07/07/09 7.1.0.1 DD 918 CP-N
: 04 07/08/08 7.9.2.3 BB 019 CG-M
: 当USER输入一些ID後,我要列出这些ID姓名(NAME)、电话(PHONE)、
: 最後一次登入的时间(TIME)与位址(IP)
: 我的想法是~ 用FOR回圈跑
: SELECT ID, NAME, PHONE, TIME, IP
: FROM LOGIN_HISTORY
: WHERE ID = 'XXX'
: AND TIME=(SELECT MAX(TIME)
: FROM LOGIN_HISTORY
: WHERE ID = 'XXX')
: 但是当输入很多ID却要QUERY很多次,非常没有效率
: 请问我SQL语法要怎麽下...会比较好?
: 最好能够一次QUERY回来~~
: 感谢你看完
sorry.. 没有看清楚..
那如果 SELECT ... FROM LOGIN_HISTORY WHERE ID IN (a,b,c,d..)
ORDER BY `TIME` DESC
结果放到 array, 再拿掉重复的呢?
如果你需要常常跑这个表出来, 另外做一个仅储存每个使用者最後一次 login
的 table, 应该会省下很多麻烦, 反正 storage 那麽便宜, 多一个 table 花
不到几块钱。
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 220.133.124.247