Как проверить и получить данные, которые находятся в массиве с помощью цикла while?

У меня есть две таблицы, и я хочу получить результат, который соответствует только массиву, вот база данных: таблица pinned, в ней хранится место применения статей

| id | article_id | pinned_sort | apply |
| 1 | 121 | 1 | a:1:{i:0;i:1;} |
| 2 | 148 | 1 | a:3:{i:0;i:2;i:1;i:2;i:2;i:3;} |
| 3 | 210 | 1 | a:3:{i:0;i:3;i:1;i:2;i:2;i:3;} |

таблица article, в ней хранятся статьи

| aid | title |
| 121 | Test 1 |
| 148 | Test 2 |
| 210 | Test 3 |

И вот моя функция

<?php
    function getArticlePinned($connectdb, $board_id = '')
    {
        $board_id = (int) $board_id;
        if (!empty($board_id)) {
            $read['query'] = 'SELECT 
            article.aid,
            article.title,
            pinned.apply 
            FROM pinned 
            INNER JOIN article ON article.aid = pinned.article_id 
            ORDER BY pinned_sort ASC';
            //Get result
            $read['stmt'] = $connectdb->stmt_init();
            $read['stmt']->prepare($read['query']);
            $read['stmt']->execute();
            $read['result'] = $read['stmt']->get_result();
            if ($read['result']->num_rows != 0) {
                while ($read['row'] = $read['result']->fetch_assoc()) {
                    //Get array from unserialize
                    $pinnedArray = unserialize($read['row']['apply']);
                    if (is_array($pinnedArray)) {
                        //Check if the board id is in array
                        if (in_array($board_id, $pinnedArray) === true) {
                            $result[] = $read['row'];
                        } else {
                            $result = false;
                        }
                    } else {
                        $result = false;
                    }
                }
            } else {
                $result = false;
            }
        } else {
            $result = false;
        }
        return $result;
    }

Но очень странно, что только когда $board_id есть 1, он может получить результат...

Какой ?! но массив генерируется функцией serialize...

carry0987 07.06.2019 14:12

@04FS тест для этого $array = array(1,2,3); echo serialize($array);

carry0987 07.06.2019 14:21

И он возвращает это a:3:{i:0;i:1;i:1;i:2;i:2;i:3;}

carry0987 07.06.2019 14:22
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
3
423
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

Я думаю, что ваш код должен инициализировать $result = false по умолчанию и позволить приведенному ниже коду работать в соответствии с ним.

function getArticlePinned($connectdb, $board_id = '')
{
    $board_id = (int) $board_id;
    $result   = false;
    if (!empty($board_id)) {
        $read['query'] = 'SELECT
            article.aid,
            article.title,
            pinned.apply
            FROM pinned
            INNER JOIN article ON article.aid = pinned.article_id
            ORDER BY pinned_sort ASC';
        //Get result
        $read['stmt'] = $connectdb->stmt_init();
        $read['stmt']->prepare($read['query']);
        $read['stmt']->execute();
        $read['result'] = $read['stmt']->get_result();
        if ($read['result']->num_rows != 0) {
            while ($read['row'] = $read['result']->fetch_assoc()) {
                //Get array from unserialize
                $pinnedArray = unserialize($read['row']['apply']);
                //Check if the board id is in array
                if (is_array($pinnedArray) && in_array($board_id, $pinnedArray)) {
                    $result[] = $read['row'];
                }
            }
        }
    }
    return $result;
}

Демо.

Потому что в цикле while вы проверяли, существует ли board_id или нет, если он не существует, вы сбрасывали/удаляли массив результатов, если совпадение, то добавляло данные в результат, поэтому впоследствии вы добавляли и удаляли данные из массива $result . Я надеюсь, что я ясно.

Rahul 07.06.2019 14:37

О, я понял, вы имеете в виду, что я просто установил $result в true и сбросил его в false, когда $board_id не находится в массиве, большое спасибо !!!!!

carry0987 07.06.2019 14:39

Точно ты меня понял :)

Rahul 07.06.2019 14:40

Боже мой ! Я починил это !! Я просто удаляю $result = false;, когда in_array возвращает false, вот код:

if (in_array($board_id, $pinnedArray) === true) {
    $result[] = $read['row'];
}

Вместо

if (in_array($board_id, $pinnedArray)) {
    $result[] = $read['row'];
} else {
    $result = false;
}

До сих пор не знаю почему, но это работает...

И можете ли вы сравнить это с моим решением, я дал что-то другое, что вы только что опубликовали?

Rahul 07.06.2019 14:32

@DrakulaPredator о, извините, я не смотрел ваш код полностью, я думал, что вы добавляете $result = false; только в начало скрипта ...

carry0987 07.06.2019 14:34

Другие вопросы по теме