PHP 板


LINE

看板 PHP  RSS
我猜你的時間都花在 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
1F:→ chrisQQ:第一個用 IN 寫起來比較簡單 07/22 00:38
2F:→ cleanwind:印象中OR效率比較好,我怕 100 多個下去會有差 07/22 00:44
3F:推 Boston:很感謝回文,我吸收一下! 07/22 00:51
4F:→ chrisQQ:是喔,我都幾千個下去 IN ... @@ 07/22 00:59
5F:→ cleanwind:我也是印象中,搞不好我印象中是錯的 XD 下次實驗看看 07/22 01:21
6F:→ dinos:有索引的話,IN,OR 的效能差距應該是微乎其微 07/22 06:56







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Boy-Girl站內搜尋

TOP