Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
12 / 11 / 8
Регистрация: 30.11.2015
Сообщений: 422

Mysql_result

27.08.2016, 10:46. Показов 1466. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Извиняюсь сразу за глупый вопрос, мануалы читаю, но все равно имеется такой вопрос. Мне необходимо выбрать запись с одного определенного поля, одного пользователя
PHP
1
2
3
4
$res = mysql_result(mysql_query("SELECT `time` FROM `users` WHERE `id`='1'"),0);
                        if(empty($res)){
                        echo "ошибка";
                        }
Вопрос в следующем, проверку производить с помощью empty на существование записи или с помощью mysql_num_rows? Если я пишу
PHP
1
if(mysql_num_rows($res)>0){
Получаю ошибку.
mysql num rows expects parameter 1
Еще вопрос, выбрать в один запрос можно с нескольких столбцов одного id? За mysql_result пишут, что только для одного поля. Или только с помощью цикла? Еще раз извиняюсь за такие вопросы, просто не ясно как лучше писать, нужен совет знающего.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.08.2016, 10:46
Ответы с готовыми решениями:

mysql_result
ПРивет. Столкнулся с таким моментом, вытаскиваю кол-во записей в таблице, но в зависисмости от второй, и вот эта ф-я // // число...

Mysql_result в pdo
Подскажите, как этот запрос выглядит в PDO:) for($m=0;$m<$list;$m++){ $user=mysql_result(mysql_query("SELECT `user` FROM...

Замена mysql_result
Комрады! Может, я туплю, но не могу найти функцию mysqli_ на замену mysql_result. Вообще есть такая??? Спасибо за ответ. ...

11
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
27.08.2016, 10:55
Цитата Сообщение от Salvat Посмотреть сообщение
как лучше писать
Лучше забыть про существование mysql_* функций и никогда не вспоминать
1
12 / 11 / 8
Регистрация: 30.11.2015
Сообщений: 422
27.08.2016, 11:01  [ТС]
Почему? Как тогда писать?

Добавлено через 59 секунд
И мой вопрос все еще актуален, как лучше?
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
27.08.2016, 11:06
Цитата Сообщение от Salvat Посмотреть сообщение
Почему?
Читал бы официальную документацию, знал бы. В описании каждой функции выделено:
Внимание Данное расширение устарело, начиная с версии PHP 5.5.0, и будет удалено в будущем. Используйте вместо него MySQLi или PDO_MySQL
Цитата Сообщение от Salvat Посмотреть сообщение
И мой вопрос все еще актуален
И в той же официально документации сказано
Обрабатываемый результат запроса. Этот результат может быть получен с помощью функции mysql_query().
http://php.net/manual/ru/funct... m-rows.php
0
392 / 294 / 121
Регистрация: 26.08.2016
Сообщений: 902
27.08.2016, 11:06
1) Данная функция и предназначена для того, чтобы получить конкретное поле конкретной строки запроса.
2) Если вы еще раз почитаете документацию, то обнаружите, что эта функция, как и все функции mysql, устарела и поддерживаться не будет, вместо них подразумевается использование функций mysqli.
3) Если вы хотите выбрать несколько полей единственной записи, можно использовать

PHP
1
2
3
4
5
6
7
8
9
$row=mysqli_fetch_array($result,MYSQLI_ASSOC);
if(!$row)
{
   echo 'Строки не существует';
}
else
{
   $columnVale = $row[$columnName];
}
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
27.08.2016, 11:08
Неправильная логика.

PHP
1
2
3
4
5
6
7
8
// Вывод ошибок на экран. Можно переделать на запись в файл.
$res = mysql_query("SELECT `time` FROM `users` WHERE `id`='1'") or die(mysql_error());
 
if(!mysql_num_rows($res))
    echo 'Пользователь не найден.';
 
// Мне больше нравится fetch_assoc, но и result тоже можно использовать, хотя не вижу смысла.
$data = mysql_fetch_assoc($res);
0
392 / 294 / 121
Регистрация: 26.08.2016
Сообщений: 902
27.08.2016, 11:52
Jodah, А mysql_num_rows обязательно использовать? Ведь если записи нет, то mysql_fetch_assoc вернет false. Или это вопрос вкуса?
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
27.08.2016, 11:55
renat_dmitriev, он не просто false вернёт, но ещё и ошибку выдаст. Потому что (см документацию) в mysql_fetch_assoc нужно ресурс соединения передавать, а никак не булево true/false.
0
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
27.08.2016, 12:14
Цитата Сообщение от Jodah Посмотреть сообщение
он не просто false вернёт, но ещё и ошибку выдаст. Потому что (см документацию) в mysql_fetch_assoc нужно ресурс соединения передавать, а никак не булево true/false.
Ошибаетесь. Ресурс будет получен, если не было ошибки при запросе. Если записей нет -- ресурс будет, но пустой.
1
392 / 294 / 121
Регистрация: 26.08.2016
Сообщений: 902
27.08.2016, 12:17
Цитата Сообщение от Jodah Посмотреть сообщение
он не просто false вернёт, но ещё и ошибку выдаст. Потому что (см документацию) в mysql_fetch_assoc нужно ресурс соединения передавать, а никак не булево true/false.
Даже если в запросе нет ни одной строки mysqli_query возвращает объект типа mysqli_result, а не булево, булево false возвращается только в случае ошибки в запросе, поэтому mysql_fetch_assoc($res) вернет либо NULL, либо массив и проверка mysql_num_rows излишня.
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
27.08.2016, 12:28
renat_dmitriev, Para bellum, упс, да, прошу прощения, всё напутал.
0
930 / 846 / 190
Регистрация: 28.11.2013
Сообщений: 3,621
27.08.2016, 23:10
Цитата Сообщение от Salvat Посмотреть сообщение
Вопрос в следующем, проверку производить с помощью empty на существование записи или с помощью mysql_num_rows?
PHP
1
2
3
4
5
if ($res=mysqli_query("SELECT `time` FROM `users` WHERE `id`='1'")) {
  if ($row=mysqli_fetch_assoc($res)) {
    ...
  } else error(404); // сообщить об отсутствии объектов, удовлетворяющих заданному условию отбора
} else error(503); // сообщить о какой-то серьезной ошибке
Добавлено через 19 минут
Эээ... в процедурном стиле у первой функции нужно указать еще один параметр на первом месте – соединение.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.08.2016, 23:10
Помогаю со студенческими работами здесь

Функция mysql_result
Подскажите пожалуйста чем можно заменить функцию mysql_result $query = "SELECT price FROM product WHERE id='$id'"; ...

Обработка ошибки mysql_result
Не нашел в интернете решения, поэтому спрошу здесь. Есть такой код: $db=" SELECT `pass` FROM table_name WHERE `num`='$num' "; ...

mysql_result или mysql_fetch_array
хочу понять что лучше. Какой код из нижеприведенных считается более правильным? Какой код при больших количествах записей в БД буте...

Функция mysql_result в PDO
Здравствуйте. Помогите, пожалуйста. Как можно заменить функцию mysql_result() в PDO? Имеется следующий код: $query =...

Чем заменить mysql_result
Здравствуйте. Запрос: "SELECT COUNT(*) FROM zakazy" // Общее количество заказов $zk = mysql_result($result, 0); mysql_result...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru