作者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
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