簡體   English   中英

Mysql存儲過程-如果未找到數據,則返回表頭

[英]Mysql Stored Procedure - Return Table headers if no Data found

我們正在使用magento和PHP。 並具有一個存儲過程,該存儲過程進行一些處理,最后假設它會使用選擇查詢返回多個結果集。

Eg : Select * FROM table1;
     Select * FROM table2;
     Select * FROM table3;

問題是,並非所有表都可能包含數據。 如果表存儲過程中沒有數據,則不返回任何內容。 在PHP中,我們使用for循環來獲取數據。

for($i= 0; $i<=3; $i++){
        $rowset = $sql->fetchAll(PDO::FETCH_ASSOC);
        if ($rowset) {
          switch ($i) {
            case 0:
              $spStatus = $rowset;
              break;
            case 1:
              $boqSections = $rowset;
              break;
            case 2:
              $boqEntries = $rowset;
              break;
            case 3:
              $boqItems = $rowset;
              break;
          }
        }
        $sql->nextRowset();
    }

因此,如果在表3中找不到數據。 存儲過程將不返回第三個行集/結果集。 因此,在上面的循環中,第三個調用$sql->fetchAll(PDO::FETCH_ASSOC); 將失敗並導致常規錯誤。

有沒有解決此問題的方法?

為rowCount添加以下條件

   for($i= 0; $i<=3; $i++){
    $rowset = $sql->fetchAll(PDO::FETCH_ASSOC); 
    if ($rowset && $sql->rowCount() >0) {
       switch ($i) {
        case 0:
          $spStatus = $rowset;
          break;
        case 1:
          $boqSections = $rowset;
          break;
        case 2:
          $boqEntries = $rowset;
          break;
        case 3:
          $boqItems = $rowset;
          break;
      }
     } else {
       $spStatus = [];
       $boqSections = [];
       $boqEntries = [];
       $boqItems = [];
     }

     $sql->nextRowset();
   }

希望這會有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM