作者cleanwind (骨傲風清(掛網))
看板PHP
標題Re: [請益] 防止資料重複寫入資料庫內
時間Sun Jul 22 00:34:15 2012
我猜你的時間都花在 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