Хранимая процедура Mysql - возвращает заголовки таблицы, если данные не найдены

0

Мы используем 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); приведет к ошибке, вызванной общей ошибкой.

Есть ли какая-нибудь работа для решения этой проблемы?

  • 0
    Каждый запрос опирается на что-то из предыдущего запроса? Какие поля имеет каждая задействованная таблица и каков результат в конце всего этого?
  • 0
    Да, каждый запрос зависит от предыдущего. 3-й стол - дочерний элемент 2-го стола, а 2-й стол - дочерний элемент 1-го стола. Но дочерние таблицы могут иметь или не иметь данные, это зависит. Однако, если есть запись в 3-й таблице, то определенно будет соответствующая запись в table2. То же самое касается данных в таблице2. Мы просто хотим убедиться, что в таблице нет данных, либо mysql должен вернуть пустую таблицу с заголовками, либо PHP должен обработать ее корректно
Показать ещё 1 комментарий
Теги:
stored-procedures
pdo
magento-1.9

1 ответ

0

Добавить условие ниже для 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();
   }

Надеюсь, это поможет.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню