Вопрос о выборе sql и массиве print_r

У меня есть вопрос, сначала посмотрите мой код:

$testsql = $db->prepare('SELECT * FROM forum_sujets');
$testsql->execute();
$test = $testsql->fetch();
print_r($test);

Моя БД:

Вопрос о выборе sql и массиве print_r

Итак, я хочу выбрать свою информацию в массиве, и я не хочу, чтобы этот массив выглядел так:

array(              
    'id' => '1', array(
        'nom' => 'test',
        'titre' => 'test',
        'auteur' => 'test',
    ),
    'id' => '2', array(
        'nom' => 'test2',
        'titre' => 'test2',
        'auteur' => 'test2',
    ),
 );

Хорошо, и после того, как мой массив будет выглядеть так, я хочу повторить, например, имя идентификатора «2», я не знаю, ясно ли я. Я надеюсь, что вы можете мне помочь, увидимся :)

ты пробовал foreach loop ?

M.Hemant 22.06.2019 11:02

Если вам нужна информация об id = 2, используйте WHERE id = 2 в своем запросе.

u_mulder 22.06.2019 11:06

Кроме того, при условии, что структура массива неверный, вы не можете иметь более одного ключа id на одном уровне массива.

u_mulder 22.06.2019 11:07

Да, я уже разместил свой запрос через некоторое время, но для оптимизации я не хочу помещать его за пределы этого времени и в то время как вызывать необходимую информацию

One 4046 22.06.2019 11:19
Стоит ли изучать 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
4
38
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Например, ваш скриншот не так хорош, поэтому я полагаю, что у вас есть таблица титра столбцов, псевдонима и автора в таблице:

$testsql = $db->prepare('SELECT id, titre, nom, auteur FROM forum_sujets');
$testsql->execute();
$data = [];
while ($test = $testsql->fetch()) {
    $id = $test['id'];
    $data[$id] = [
        'nom' => $test['nom'],
        'auteur' => $test['auteur'],
        'title' => $test['title'],
    ];
}

print_r($data);

Вывод будет таким:

array(              
    1 => array(
        'nom' => 'test',
        'titre' => 'test',
        'auteur' => 'test',
    ),
    2 => array(
        'nom' => 'test2',
        'titre' => 'test2',
        'auteur' => 'test2',
    ),
 );

Поскольку у вас не может быть двух одинаковых ключей в одном массиве

Неплохо. Я только хотел отметить, что @u_mulder, вероятно, прав в своем комментарии выше, что BaguetteV1.0 на самом деле ищет только одну запись. Поэтому использование предложения WHERE может быть лучшим подходом. Но мы не можем быть уверены, пока не будет объяснено, как работает весь код и для чего он нужен.

HonzaOne 22.06.2019 11:47

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