Форум программистов, компьютерный форум, киберфорум
PHP
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54

Как вывести из таблицы полное описание по id?

19.08.2020, 14:33. Показов 2069. Ответов 25

Студворк — интернет-сервис помощи студентам
Добрый день!
есть таблица `test` с значениями `id` , `user_id` , `product_id`
и таблица `product` с полями `id`, `name`, `price`.
к примеру нужно чтобы на сайте в таблице `test` - при выборе айди 3 продукта выходила информация о нем в цикле.
чтобы было примерно понятно, то речь идет о реализации вкладки "избранное"
ниже пример кода с выводом
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
$notice_arr = $mysqli->query("SELECT * FROM `test` WHERE `id_user`='".$arr['id']."' ORDER BY `id` DESC");
 
 
 
 
 
 
 
if (isset($_GET['del'])) {
  $id = $_GET['del'];
  $delete = $mysqli->query("DELETE FROM `test` WHERE `id` = '".$id."';");
  header("Location: favorites.php");
}
 
?>
 
<body>
    <?php require_once 'app/header.php'; ?>
    <div class="container text-center">
        <h2>избранное</h2>
<div class="row">
    <div class="col-md-2 col-sm-12"></div>
    <div class="col-md-8 col-sm-12">
        <?php
 
        while ($array = $notice_arr->fetch_assoc()){
 
    $query = " SELECT * FROM `products` WHERE `id`='".$id."'";
    $result = mysqli_query($mysqli,$query);
 
    while ($array = mysqli_fetch_assoc($result)) {
        $id = $array['id'];
        $name = $array['name'];
        $price = $array['price'];
        $photo = $array['photo'];
    }
            echo "
<div class='media border p-3'>
    <img src='uploads/".$array['photo']."' alt='favorite' class='mr-3 mt-3 rounded-circle' style='width:60px;'>
    <div class='media-body'><a class='text-light' href='?del=".$array['id']."'><button class='btn btn-danger float-right'>x</button></a>
      <h4>".$name."</h4> 
      <p><b>".$price." рублей</b> - перед покупкой ознакомьтесь с <a href=''>правилами покупки</a></p>      
    </div>
  </div>
            ";
        }
        ?>
 
    </div>
    <div class="col-md-2 col-sm-12"></div>
</div>
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.08.2020, 14:33
Ответы с готовыми решениями:

Как найти координату точки по оси X на дуге окружности? (Полное описание внутри)
Центр окружности неизвестен. Но известен радиус R=10. И известны координаты точки A(16;27) Нужно найти координату Х точки B(x;29) на...

Полное описание методов у RecordSet
Господа (граждане, товарищи,...), программисты! Где можно посмотреть полное описание (или хотя бы просто список) методов у RecordSet? ...

полное описание настроек модема
доброго времени суток, уважаемые форумчане! давно пользуюсь инетом через модем (zyxel, а сейчас glitel) но это не особо важно. как...

25
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 17:05
Лучший ответ Сообщение было отмечено kkksfd как решение

Решение

MySQL
1
... LEFT JOIN `product` ON `test`.`product_id`=`product`.`id`
Добавлено через 2 минуты
Если бы связующее поле называлось одинаково в обеих таблицах, вместо выражения ON можно было просто написать USING(`product`), где product - имя связующего поля.

Добавлено через 5 минут
Не смешивайте HTML-код и код взаимодействия с базой данных. После заголовка Location не выводите обычное содержимое. Значение входного параметра без его проверки нельзя вставлять в неподготовленный запрос. В $result может появляться значение, способное вызвать ошибку в fetch_assoc, поэтому его нужно предварительно проверять. Без необходимости не используйте _once (вряд ли еще где-то в этом коде вы захотите подключить app/header.php).
1
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 17:12  [ТС]
estic, Спасибо Вам!
0
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 17:14
...В шаблонах используется другой синтаксис while и т.п. (пример можно посмотреть здесь).

Цитата Сообщение от kkksfd Посмотреть сообщение
Спасибо Вам!
Можно не благодарить. Просто исправьте все, что я перечислил
1
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 17:15  [ТС]
estic, еще вопрос, а как именно вставить мускл? т.к. у меня сразу выдает ошибку
0
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 17:29
На месте многоточия должно быть обычное начало текста запроса, включая указание основной для данного запроса таблицы (test). Например:
MySQL
1
SELECT `user_id`, `product`.* FROM `test`...
Добавлено через 7 минут
Учитесь самостоятельно находить ответы по подсказкам. Ключа "LEFT JOIN" более чем достаточно, чтобы получить подробнейший ответ на ваш вопрос из Интернета
0
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 17:31  [ТС]
estic, все равно выдает ошибку, сейчас все подправил, запрос заменил на Ваш с " SELECT * FROM `products` WHERE `id`='".$id."'",
на
"SELECT * FROM `test` LEFT JOIN `product` ON `test`.`product_id`=`product`.`id`"
теперь цикл вообще не срабатывает
0
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 17:35
У вас там зачем-то два цикла, причем записанных с разным mysqli-синтаксисом
0
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 17:37  [ТС]
estic, просто вот пример задачи.
человек через сессию должен закинуть товар в избранное, но проблема в том, что я захотел сделать это через таблицу `test`, где хранится id пользователя и его товаров.
а второй скрин с этим товаром и его айди (к примеру), но я не знаю как вывести через таблицу "test" через цикл все его избранное товары.(

p.s. id пользователя идет с сессии,
Миниатюры
Как вывести из таблицы полное описание по id?   Как вывести из таблицы полное описание по id?  
0
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 17:38  [ТС]
estic, забыл их удалить, т.к. уже максимально отчаялся)
там только один цикл был, но я думал через GetID, но это полный бред, т.к. я не открываю страницу новую
0
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 17:47
Если вам нужно выбрать товары авторизованного пользователя, то нужно добавить в запрос условие наподобие `user_id`={$user['id']}, но и без него ошибки быть не должно (просто будут выбраны товары всех пользователей).
0
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 17:49  [ТС]
estic, да, он у меня выше стоит уже, я просто не кидал запрос с сессией, у меня именно проблема с выводом наименование и названием товара

Добавлено через 53 секунды
estic, т.е. я могу вывести цикл с избранным пользователя и айди продукта, но именно само наименование и цену нет(
0
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 17:50
У вас в таблице товаров должны быть описаны все товары из test, а то вы ссылаетесь на товары 2 и 4, а в таблице товаров у вас находится только товар с id=1.
0
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 17:53  [ТС]
estic, да, я забыл об этом написать (там еще вторая страница с id=1)
0
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 18:11
Вы много чего забыли написать, например, то что поля называются id_user и id_product Отдохните
0
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 18:16  [ТС]
estic, Я в начале темы писал о них)
0
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 18:18
Цитата Сообщение от kkksfd Посмотреть сообщение
Я в начале темы писал о них)
Уверены? Процитируйте
0
0 / 0 / 0
Регистрация: 05.02.2020
Сообщений: 54
19.08.2020, 18:22  [ТС]
estic,
Цитата Сообщение от kkksfd Посмотреть сообщение
таблица `test` с значениями `id` , `user_id` , `product_id`
0
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,883
19.08.2020, 18:23
Не вижу
0
19.08.2020, 18:24

Не по теме:

Все, увольняюсь из "Спокойной ночи, малыши" :)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
19.08.2020, 18:24
Помогаю со студенческими работами здесь

Полное описание kernel32.dll
Где можно добыть описание Kernel32.dll ?

BSOD (полное описание внутри)
Всем привет! Борюсь с этим уже месяца 2, но видимо все-таки моих знаний не хватает. История такая: компьютер работает стабильно...

Полное правильное описание двумерного массива
#include&lt;iostream&gt; #include&lt;cstdlib&gt; #include&lt;ctime&gt; using namespace std; void vvod(int , int, int); void vvod(int f, int n, int...

Где найти полное описание Хранимых процедур?
Люди! Не могу я больше рыскать по инету в поисках описание. пальцы по клавишам не попадают :((( Ну не могу я найти описнаие хранимых...

Реализовать полное описание товара на отдельной странице
Как реализовать полное описание к примеру (товара) на сайте? Сделал такой вывод: &lt;p&gt; &lt;a href=&quot;./?id=', $row, '&quot;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru