第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

為什么mysqli給出“命令不同步”錯(cuò)誤?

為什么mysqli給出“命令不同步”錯(cuò)誤?

慕田峪7331174 2019-08-05 15:39:50
為什么mysqli給出“命令不同步”錯(cuò)誤?我正在嘗試運(yùn)行以下內(nèi)容。<?php $db = mysqli_connect("localhost","user","pw") or die("Database error");mysqli_select_db($db, "database");$agtid = $_POST['level'];$sql = sprintf("call agent_hier(%d)", $agtid);$result = mysqli_query($db, $sql) or exit(mysqli_error($db));if ($result) {     echo "<table border='1'>         <tr><th>id</th>         <th>name</th>         <th>parent_id</th>         <th>parent_name</th>         <th>level</th>         <th>email</th></tr>";     while ($row = mysqli_fetch_assoc($result))      {         $aid = $row["id"];         $sql2 = "SELECT * FROM members WHERE MEMNO = '$aid'";         $result2 = mysqli_query($db,$sql2) or exit(mysqli_error($db));             while ($newArray = mysqli_fetch_array($result2)) {                 $fname = $newArray['FNAME'];                 $lname = $newArray['LNAME'];                 $mi = $newArray['MI'];                   $address = $newArray['ADDRESS'];                     $city = $newArray['CITY'];                   $state = $newArray['STATE'];                     $zip = $newArray['ZIP'];                             $kdate = $newArray['KDATE'];                 $date = abs(strtotime(date('m/d/Y')) - strtotime(date($kdate))) / (60 * 60 * 24);             }         echo sprintf("<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>",             $row["id"],$row["name"],             $row["parent_id"],$row["parent_name"],             $row["level"],$row["email"]);     }     echo "</table>";}mysqli_free_result($result);mysqli_close($db);?>如果我刪除以下行:  $aid = $row["agent_id"];至....  $date = abs(strtotime(date('m/d/Y')) - strtotime(date($kdate))) / (60 * 60 * 24);   }一切都會(huì)好起來(lái)的。如果沒(méi)有,我收到以下錯(cuò)誤:命令不同步; 你現(xiàn)在不能運(yùn)行這個(gè)命令在研究,我認(rèn)為這可能是由于在同一時(shí)間運(yùn)行多個(gè)MySQLi的查詢,其中使用mysqli_multi_query,但所有樣品和一般數(shù)據(jù)的引導(dǎo)似乎并不適用。有任何想法嗎?
查看完整描述

3 回答

?
慕妹3146593

TA貢獻(xiàn)1820條經(jīng)驗(yàn) 獲得超9個(gè)贊

MySQL客戶端不允許您執(zhí)行新查詢,其中仍有從正在進(jìn)行的查詢中提取的行。有關(guān)常見錯(cuò)誤,請(qǐng)參閱MySQL文檔中的命令不同步。

您可以使用mysqli_store_result()從外部查詢中預(yù)取所有行。這將在MySQL客戶端中緩沖它們,因此從服務(wù)器的角度來(lái)看,您的應(yīng)用程序已獲取完整的結(jié)果集。然后,即使在從now-buffered外部結(jié)果集中獲取行的循環(huán)中,您也可以執(zhí)行更多查詢。

或者您mysqli_result::fetch_all()將完整的結(jié)果集作為PHP數(shù)組返回,然后您可以循環(huán)該數(shù)組。

調(diào)用存儲(chǔ)過(guò)程是一種特殊情況,因?yàn)榇鎯?chǔ)過(guò)程有可能返回多個(gè)結(jié)果集,每個(gè)結(jié)果集可能有自己的一組行。這就是為什么@ a1ex07的回答提到使用mysqli_multi_query()和循環(huán)直到mysqli_next_result()沒(méi)有更多的結(jié)果集。這是滿足MySQL協(xié)議所必需的,即使在您的情況下您的存儲(chǔ)過(guò)程只有一個(gè)結(jié)果集。


PS:順便說(shuō)一句,我看到你正在進(jìn)行嵌套查詢,因?yàn)槟阌写韺哟谓Y(jié)構(gòu)的數(shù)據(jù)。您可能需要考慮以不同方式存儲(chǔ)數(shù)據(jù),以便您可以更輕松地查詢它。我做了一個(gè)關(guān)于這個(gè)標(biāo)題為SQL和PHP的分層數(shù)據(jù)模型的演示文稿。我還在我的SQL反模式:避免數(shù)據(jù)庫(kù)編程陷阱的一章中討論了這個(gè)主題。


以下是如何mysqli_next_result()在CodeIgnitor 3.0.3中實(shí)現(xiàn):

system/database/drivers/mysqli/mysqli_driver.php變化的第262行

protected function _execute($sql){
    return $this->conn_id->query($this->_prep_query($sql));}

對(duì)此

protected function _execute($sql){
    $results = $this->conn_id->query($this->_prep_query($sql));
    @mysqli_next_result($this->conn_id); // Fix 'command out of sync' error
    return $results;}

這是自2.x以來(lái)的一個(gè)問(wèn)題。我剛剛更新到3.x并且不得不將這個(gè)hack復(fù)制到新版本。


查看完整回答
反對(duì) 回復(fù) 2019-08-05
?
繁花如伊

TA貢獻(xiàn)2012條經(jīng)驗(yàn) 獲得超12個(gè)贊

簡(jiǎn)單地說(shuō),在調(diào)用mysqli_free_result之后,你必須調(diào)用mysqli_next_result($ db)。

mysqli_free_result($結(jié)果); mysqli_next_result($ db) mysqli_close($ db);


查看完整回答
反對(duì) 回復(fù) 2019-08-05
?
倚天杖

TA貢獻(xiàn)1828條經(jīng)驗(yàn) 獲得超3個(gè)贊

只需調(diào)用此函數(shù):

$this->free_result();function free_result() {
        while (mysqli_more_results($this->conn) && mysqli_next_result($this->conn)) {

            $dummyResult = mysqli_use_result($this->conn);

            if ($dummyResult instanceof mysqli_result) {
                mysqli_free_result($this->conn);
            }
        }
    }


查看完整回答
反對(duì) 回復(fù) 2019-08-05
  • 3 回答
  • 0 關(guān)注
  • 541 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)