看板 PHP 關於我們 聯絡資訊
我猜你的時間都花在 PHP 和 MySQL 連接上, 不知道你這樣踢踢看,效率會不會好點? $sqlStr = ''; foreach($_SESSION['statuses']['data'] as $s) { $sqlStr .= 'OR `status_id` = \''.$s['id'].'\''; } $sqlStr = substr($sqlStr, 2); $result = mysql_query('SELECT `status_id` FROM `status` WHERE'.$sqlStr); $k = 0; while($R = mysql_fetch_row($result)) { $exist[$k] = $R[0]; $k ++; } foreach($_SESSION['statuses']['data'] as $s) { if(!in_array($s['id'], $exist)) { //沒有重複的才會開始動作。 } } 你先試試看這樣做有沒有效過, 有的話再去做精簡 ... ※ 引述《Boston (Boston)》之銘言: : 是這樣的 : 由於每次跑php都跑很久(或許是寫入的迴圈跑太多) : 所以必須把資料防止重複寫進資料庫內 : 於是我寫了以下程式碼: : foreach($_SESSION['statuses']['data'] as $s) : { : $status_id=$s['id']; : /*開始判斷是否有重複資料*/ : $sql = "SELECT * FROM `status`where `status_id`='$status_id'"; : $result = mysql_query($sql); : $row = mysql_fetch_row($result); : : if($row[status_id]!=$status_id) 開始判斷 : { : $user_id=$s['from']['id']; : $status_message=$s['message']; : $status_updated_time=substr($s['updated_time'],0,19); : $status_likes_numbers=count($s['likes']['data']); : . : . : . : . : . : } : } : /*結束判斷是否有重複資料*/ : if($dbin) : { : echo "status資料已寫入"; : } : else : { : echo "status寫入失敗"; : } : } : 大概是這樣的防止重複資料寫入 : 我是利用session的值跟sql主鍵的值判斷後,來決定資料是否要寫入 : 但是這方法寫好後,php網頁還是跑很慢 : 於是就在想能不能把判斷寫在迴圈外? : 這樣的話就不用一直跑回圈判斷是否寫入,並且加速php讀取速度? : 以及可以寫在迴圈外判斷是否寫入的話,該如何撰寫程式碼呢? : php新手,請版友們多指教 : ps.user單一資料量預估至少上百筆 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 120.101.9.24
chrisQQ:第一個用 IN 寫起來比較簡單 07/22 00:38
cleanwind:印象中OR效率比較好,我怕 100 多個下去會有差 07/22 00:44
Boston:很感謝回文,我吸收一下! 07/22 00:51
chrisQQ:是喔,我都幾千個下去 IN ... @@ 07/22 00:59
cleanwind:我也是印象中,搞不好我印象中是錯的 XD 下次實驗看看 07/22 01:21
dinos:有索引的話,IN,OR 的效能差距應該是微乎其微 07/22 06:56