С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
-5 / 1 / 0
Регистрация: 15.11.2015
Сообщений: 70

Вывод из массива json

21.05.2018, 10:16. Показов 1515. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите, как сделать так ,чтобы в случае если пользователь не задал никаких параметров поиска, а просто нажал на кнопку выводилась в вся информация из таблиц БД?
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
<?php
define(HOST, "localhost");
define(USER, "root");
define(PW, "");
define(DB, "kino");
 
$connect = mysql_connect(HOST,USER,PW)
or die('Could not connect to mysql server.' );
 
mysql_select_db(DB, $connect)
or die('Could not select database.');
 
$term = strip_tags(substr($_POST['search_term'],0, 100));
$term = mysql_escape_string($term);
 
$sql = "select  name, description, data, time, hall, ticket_price
from film, seans where film.id=seans.film and
film.id like '%$term%'
order by name asc";
 
$result = mysql_query($sql);
$string = '';
 
$row = mysql_fetch_object($result);
 
 
echo  json_encode($row, JSON_UNESCAPED_UNICODE);
 
 
?>
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.05.2018, 10:16
Ответы с готовыми решениями:

Вывод данных из json массива
Добрый вечер, ночь, утро, день. Есть php файл выдающий json: if (!mysql_connect(localhost, hies, root)) { exit; } ...

Вывод массива из json
{ &quot;info&quot;: { &quot;people&quot;: } } Нужно вывсети в таблицу значения из всех age и name. И возможно как-то сделать, чтобы 2...

Json. вывод из массива
{&quot;response&quot;:} Как из этой строчки вытащить например имя? $obj = json_decode($news, true); echo...

12
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
21.05.2018, 11:20
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
$term = strip_tags(substr($_POST['search_term'],0, 100));
$term = mysql_escape_string($term);
 
if($term==""){
    $poisk = "!= ''";
}else{
    $poisk = "like '%$term%'";
}
 
$sql = "select  name, description, data, time, hall, ticket_price
from film, seans where film.id=seans.film and
film.id $poisk
order by name asc";
0
-5 / 1 / 0
Регистрация: 15.11.2015
Сообщений: 70
21.05.2018, 12:07  [ТС]
выводит только вторую запись из таблицы
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
21.05.2018, 12:14
Тогда так:
PHP
1
2
3
4
5
6
7
8
9
if($term==""){
    $poisk = "";
}else{
    $poisk = "and film.id like '%$term%'";
}
 
$sql = "select  name, description, data, time, hall, ticket_price
from film, seans where film.id=seans.film $poisk
order by name asc";
0
-5 / 1 / 0
Регистрация: 15.11.2015
Сообщений: 70
21.05.2018, 12:17  [ТС]
тоже самое
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
21.05.2018, 12:20
Какое значение у второй записи film.id ?
Что выводит этот код: echo $term; ?
0
-5 / 1 / 0
Регистрация: 15.11.2015
Сообщений: 70
21.05.2018, 12:26  [ТС]
значение у второй записи 2, если в поиск написать id 1 то выводит цифру 1 и т.д.
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
21.05.2018, 12:40
Если $_POST['search_term'] пустой, то sql запрос будет таким:
SQL
1
2
3
SELECT  name, description, DATA, TIME, hall, ticket_price
FROM film, seans WHERE film.id=seans.film
ORDER BY name ASC
что означает выбор всех записей у которых совпадают film.id с seans.film

А если $_POST['search_term'] не пустой, то сработает дополнительное условие:
SQL
1
AND film.id LIKE '%$term%'
Посмотрите как выглядит sql запрос при пустом $_POST['search_term']
PHP
1
echo $sql;
0
-5 / 1 / 0
Регистрация: 15.11.2015
Сообщений: 70
21.05.2018, 12:55  [ТС]
Так?
Миниатюры
Вывод из массива json  
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
21.05.2018, 13:20
Да. Только обратите внимание на название полей: DATA, TIME, это зарезервированные имена. Обрамляйте имена таблиц и полей обратными кавычками:
SQL
1
2
3
SELECT  `name`, `description`, `data`, `time`, `hall`, `ticket_price`
FROM `film`, `seans` WHERE `film`.`id`=`seans`.`film`
ORDER BY `name` ASC
0
-5 / 1 / 0
Регистрация: 15.11.2015
Сообщений: 70
21.05.2018, 13:28  [ТС]
выводит только одно значение
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
21.05.2018, 13:56
Значит под условие попадает только одна запись.

Проверьте таким образом:
SQL
1
SELECT * FROM `film`,`seans` WHERE `film`.`id`=`seans`.`film`
И если выборка идёт из двух таблиц, то имена полей тоже нужно причислять к таблицам:
SQL
1
2
3
SELECT  `film`.`name`, `film`.`description`, `film`.`data`, `film`.`time`, `film`.`hall`, `film`.`ticket_price`
FROM `film`, `seans` WHERE `film`.`id`=`seans`.`film`
ORDER BY `film`.`name` ASC
Но всё это можно использовать только для отладки скрипта, а выборку из нескольких таблиц нужно делать через join.
0
-5 / 1 / 0
Регистрация: 15.11.2015
Сообщений: 70
24.05.2018, 15:30  [ТС]
Добавил этот код и все заработало
PHP
1
2
3
4
5
if (mysql_num_rows($result) > 0){
  while($row = mysql_fetch_object($result)){
   echo  json_encode($row, JSON_UNESCAPED_UNICODE);
 }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.05.2018, 15:30
Помогаю со студенческими работами здесь

Вывод JSON массива диалогов ВК
Здравствуйте, пытаюсь вывести JSON массив из файла. Сделал пока так, ради теста, файл читается и данные выводятся. $j =...

Вывод ассоциативного массива Json
Есть функция которая получает прогноз forecast.get(, function (err, result) { if (err) { return console.dir(err); }...

Ajax вывод JSON массива
Пытаюсь вывести список регионов при нажатии на кнопку, выводит \u041c\u043e\u0441\u043a\u0432\u0430 \u0438...

Json вывод массива в php
Здравствуйте, загружаю json массив через ajax для обработки, для проверки его вывожу назад получаю null вычитала что из-за...

Вывод значения из массива [PHP + JSON]
Всем привет:Вот проблемка есть массив,каким образом можно вытащить значения,с -&gt; =&gt; stdClass Object и с =&gt; =&gt; stdClass...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru