首頁 > 後端開發 > php教程 > while 迴圈裡面需要 query和ajax

while 迴圈裡面需要 query和ajax

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-09-09 08:28:01
原創
849 人瀏覽過

我想問大家寫法跟我是不是一樣?
假設我要用迴圈撈資料時

<code>while ($row=mysql_fetch_array($sql)){ 
資料顯示...
}
</code>
登入後複製
登入後複製

但假設我需要迴圈資料中的$row[id]去做其他事情
我就得把mysql_query放進while裡面 這樣我才能知道每一筆的$row[id]
像這樣

<code>while ($row=mysql_fetch_array($gettimeline)){
$sql2 = mysql_query("SELECT * FROM `xxx`
WHERE `id` = '".$row['id']."'
");
}
</code>
登入後複製
登入後複製

那這樣每一筆資料撈出來之後
他不就會重複每一筆的$sql2查詢?
這樣寫法是對的嗎
以及ajax也是一樣
假設我要刪除某文章 為了取得該文章id我還是得把它放進while迴圈內

<code>while ($row=mysql_fetch_array($gettimeline)){

$sql2 = mysql_query("SELECT * FROM `xxx`
WHERE `id` = '".$row['id']."'
");

<script>
                        $("#remove_timeline_<? echo $row['timeline_id'];?>").click(function(){
                                $.ajax({
                                    type: "POST",
                                    url:"remove?to=<? echo $row['timeline_id'];?>",
                                    cache: false,
                                    success: function(){    
                                    
                                    }
                                });
                            }
                        });
                        </script>
                        }
</code>
登入後複製
登入後複製

這樣每一筆都會有重複的ajax和query 越多筆一定會越慢吧....
請問大家會怎麼做?

回覆內容:

我想問大家寫法跟我是不是一樣?
假設我要用迴圈撈資料時

<code>while ($row=mysql_fetch_array($sql)){ 
資料顯示...
}
</code>
登入後複製
登入後複製

但假設我需要迴圈資料中的$row[id]去做其他事情
我就得把mysql_query放進while裡面 這樣我才能知道每一筆的$row[id]
像這樣

<code>while ($row=mysql_fetch_array($gettimeline)){
$sql2 = mysql_query("SELECT * FROM `xxx`
WHERE `id` = '".$row['id']."'
");
}
</code>
登入後複製
登入後複製

那這樣每一筆資料撈出來之後
他不就會重複每一筆的$sql2查詢?
這樣寫法是對的嗎
以及ajax也是一樣
假設我要刪除某文章 為了取得該文章id我還是得把它放進while迴圈內

<code>while ($row=mysql_fetch_array($gettimeline)){

$sql2 = mysql_query("SELECT * FROM `xxx`
WHERE `id` = '".$row['id']."'
");

<script>
                        $("#remove_timeline_<? echo $row['timeline_id'];?>").click(function(){
                                $.ajax({
                                    type: "POST",
                                    url:"remove?to=<? echo $row['timeline_id'];?>",
                                    cache: false,
                                    success: function(){    
                                    
                                    }
                                });
                            }
                        });
                        </script>
                        }
</code>
登入後複製
登入後複製

這樣每一筆都會有重複的ajax和query 越多筆一定會越慢吧....
請問大家會怎麼做?

「迴圈」是「循環」的意思吧?


到資料量條數變多的時候,請求數也會變多,一般這種重複類似的外部 IO 都會考慮合併。
比如:

SELECT * FROM `xxx` WHERE id in (1,2,3,4,5)
登入後複製
相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
angular.js - Angularjs $http ajax問題?
來自於 1970-01-01 08:00:00
0
0
0
ajax點擊提交沒反應!
來自於 1970-01-01 08:00:00
0
0
0
javascript - autocomplete ajax怎麼配置,求教
來自於 1970-01-01 08:00:00
0
0
0
ajax 學習需要什麼基礎
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板