Re: [請益] 防止資料重複寫入資料庫內

看板PHP作者 (骨傲風清(掛網))時間12年前 (2012/07/22 00:34), 編輯推噓1(105)
留言6則, 4人參與, 最新討論串2/2 (看更多)
我猜你的時間都花在 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

07/22 00:38, , 1F
第一個用 IN 寫起來比較簡單
07/22 00:38, 1F

07/22 00:44, , 2F
印象中OR效率比較好,我怕 100 多個下去會有差
07/22 00:44, 2F

07/22 00:51, , 3F
很感謝回文,我吸收一下!
07/22 00:51, 3F

07/22 00:59, , 4F
是喔,我都幾千個下去 IN ... @@
07/22 00:59, 4F

07/22 01:21, , 5F
我也是印象中,搞不好我印象中是錯的 XD 下次實驗看看
07/22 01:21, 5F

07/22 06:56, , 6F
有索引的話,IN,OR 的效能差距應該是微乎其微
07/22 06:56, 6F
文章代碼(AID): #1G2je9w9 (PHP)
文章代碼(AID): #1G2je9w9 (PHP)