С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
52 / 35 / 16
Регистрация: 03.08.2019
Сообщений: 389

PDO в MySQL. Ошибки и прочее

06.08.2019, 16:48. Показов 1973. Ответов 6

Студворк — интернет-сервис помощи студентам
Всем привет.
имеется следующий код:
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
<?php 
 
    $host = 'localhost';
    $db   = 'test_db';
    $user = 'root';
    $pass = '';
    $charset = 'utf8';
 
    $dsn = "mysql:host=$host;dbname=$db;charset=$charset";
    $opt = [
        PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
        PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
        PDO::ATTR_EMULATE_PREPARES   => false,
    ];
    $pdo = new PDO($dsn, $user, $pass, $opt);
 
 
$wheat = 'Пшеница';
$barley = 'Ячмень';
$corn = 'Кукуруза';
$peas = 'Горох';
 
updateRandomCost($wheat);
// updateRandomCost($barley);
// updateRandomCost($corn);
// updateRandomCost($peas);
 
function updateRandomCost ($str) {
    $stmt = $pdo->prepare("UPDATE price set cost = :cost WHERE val = :val");
    $stmt->bindParam(':val', $val, PDO::PARAM_STR);
    $stmt->bindParam(':cost', $cost, PDO::PARAM_INT);
    $val = $str;
    $cost = mt_rand(1000, 5000);
    $stmt->execute();
}
 
 
 
 
 
// $wheat = $pdo->prepare("UPDATE price set cost = :cost WHERE val = :val");
// $wheat->bindParam(':val', $val, PDO::PARAM_STR);
// $wheat->bindParam(':cost', $cost, PDO::PARAM_INT);
// $val = 'Пшеница';
// $cost = mt_rand(1000, 5000);
// $wheat->execute();
 
 
 
// $barley = $pdo->prepare("UPDATE price set cost = :cost WHERE val = :val");
// $barley->bindParam(':val', $val, PDO::PARAM_STR);
// $barley->bindParam(':cost', $cost, PDO::PARAM_INT);
// $val = 'Ячмень';
// $cost = mt_rand(1000, 5000);
// $barley->execute();
 
 
// $corn = $pdo->prepare("UPDATE price set cost = :cost WHERE val = :val");
// $corn->bindParam(':val', $val, PDO::PARAM_STR);
// $corn->bindParam(':cost', $cost, PDO::PARAM_INT);
// $val = 'Кукуруза';
// $cost = mt_rand(1000, 5000);
// $corn->execute();
 
 
// $peas = $pdo->prepare("UPDATE price set cost = :cost WHERE val = :val");
// $peas->bindParam(':val', $val, PDO::PARAM_STR);
// $peas->bindParam(':cost', $cost, PDO::PARAM_INT);
// $val = 'Горох';
// $cost = mt_rand(1000, 5000);
// $peas->execute();
 
 
 ?>
дабы не плодить несколько раз фактически один и тот же код (который закоментирован) написал функцию.
при запуске файла получаю облом в виде ошибки:
Fatal error: Uncaught Error: Call to a member function prepare() on null in D:\OPserver\OSPanel\domains\test\test.ph p:29
"Великий" всезнайка Гугл только запутал еще больше.
Ребят, подскажите, пожалуйста, в чем ошибка?
перепробовал с десяток вариантов, а при запуске только ошибки получаю
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.08.2019, 16:48
Ответы с готовыми решениями:

Использование PDO и MySQL
Есть функция, никак не могу понять почему не работает: function developer_get_profile ($login) { global $config, $DBH; ...

Php,MySql,PDO
Здравствуйте подскажите пожалуйста как переделать данный класс чтобы он работал не с PDO а с MySql &lt;?php namespace...

Singleton и PDO::MYSQL
Здравствуйте. Пытаюсь организовать работу с БД используя шаблон Singleton. В интернете нашел такой пример. Но тут используется устаревший...

6
17 / 7 / 10
Регистрация: 25.05.2018
Сообщений: 46
06.08.2019, 16:59
PHP
1
2
3
4
$stmt->bindParam(':val', $val, PDO::PARAM_STR);
$stmt->bindParam(':cost', $cost, PDO::PARAM_INT);
$val = $str;
$cost = mt_rand(1000, 5000);
Вы биндите параметры, а потом в переменные присваиваете значения, я думаю тут нужно сделать наоборот:
PHP
1
2
3
4
5
$val = $str;
$cost = mt_rand(1000, 5000);
 
$stmt->bindParam(':val', $val, PDO::PARAM_STR);
$stmt->bindParam(':cost', $cost, PDO::PARAM_INT);
0
52 / 35 / 16
Регистрация: 03.08.2019
Сообщений: 389
06.08.2019, 17:48  [ТС]
Цитата Сообщение от Heretic_tr4 Посмотреть сообщение
Вы биндите параметры, а потом в переменные присваиваете значения, я думаю тут нужно сделать наоборот:
этот вариант был первым) результат одинаковый..
если отправлять каждый запрос отдельно то расстановка роли не играет. работае одинаково и безотказно
0
17 / 7 / 10
Регистрация: 25.05.2018
Сообщений: 46
06.08.2019, 18:02
Лучший ответ Сообщение было отмечено Fantom1987 как решение

Решение

Передавайте $pdo в функцию как аргумент, т.к. там другая область видимости.
Или создавайте подключение в БД прямо в функции.

PHP
1
2
3
4
5
6
7
8
9
10
updateRandomCost($pdo, $wheat);
function updateRandomCost ($pdo, $str) {
    $val = $str;
    $cost = mt_rand(1000, 5000);
 
    $stmt = $pdo->prepare("UPDATE price set cost = :cost WHERE val = :val");
    $stmt->bindParam(':val', $val, PDO::PARAM_STR);
    $stmt->bindParam(':cost', $cost, PDO::PARAM_INT);
    $stmt->execute();
}
1
52 / 35 / 16
Регистрация: 03.08.2019
Сообщений: 389
06.08.2019, 18:43  [ТС]
Цитата Сообщение от Heretic_tr4 Посмотреть сообщение
Передавайте $pdo в функцию как аргумент, т.к. там другая область видимости.
уууупппппсссссс
а вот на этот факт внимания не обратил
Благодарю
0
52 / 35 / 16
Регистрация: 03.08.2019
Сообщений: 389
22.08.2019, 14:50  [ТС]
Уважаемые знатоки, хэлп!
для Вас скорей всего это мелочи, но для меня пока не понятно и гугл в этом особо не помог
Имею:
форма регистрации которая принимает nickname, login, password, email, phone и еще password_2 для проверки на правильность введенного пароля
прежде чем зарегать пользователя естественно нужно проверить на совпадение данных в БД
на уровне БД nickname, login, email, phone поставил индекс Уникальный. если это делать не надо было, то критика приветствуется
итак, чтобы проверить эти данные, то нужно написать 20-30 строк одинакового кода. а это есть не хорошо. поэтому в идеале нужна функция, которая будет принимать на вход значение из полей, обрабатывать, и если есть совпадение, то выводить сообщение, что если:
nickname уже существует, то вывести сообщение типа: такой ник уже существует, занят.. короче облом
и так с остальными.
теоретически выглядит все так, а как реализовать это в коде с учетом PDO - в замешательстве)
Буду очень благодарен за Ваши подсказки в реализации данного функционала.
0
52 / 35 / 16
Регистрация: 03.08.2019
Сообщений: 389
05.09.2019, 19:33  [ТС]
Знатоки, подскажите, пожалуйста возможно ли такое.
Мне одним PDO запросом нужно отправить два SELECT на выборку из разных таблиц и оба запроса с условием.
При попытке это сделать через query или prepare получаю ошибку:
Fatal error: Uncaught PDOException: SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near
Гугл выдал пару статеек в которых ответы на эту тему разные. Одни говорят что можно сделать, но с примерами беда, а другие рассказываю, что это не возможно вообще.
Кто сталкивался? Подскажите как правильно оформить подобный запрос.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.09.2019, 19:33
Помогаю со студенческими работами здесь

Работа с БД MySQL | PDO
Работа с БД MySQL в PHP Данный пост решил написать в дополнение Работа с БД MySQL в PHP автор (KOPOJI). Преимущества PDO: ...

Как реализовать на PDO с MySql ?
вообщем есть готовый код $result = mysql_query(&quot;SELECT * FROM klient WHERE phone='$phone'&quot;); $myrow = mysql_fetch_array($result);...

Какая-то фигня с PDO MySQL
Всем привет! есть класс: &lt;?php class DB_PDO_MySQL extends DB { public static $pdo;

Ошибка подключения к СУБД MySQL PDO
Здравствуйте. Установлен Open Server, на нём PHP 7.2 и MySQL 5.7. Имя базы данных test, хост, логин и парроль по умолчанию. При...

PDO не получается сделать выборку из MySQL
Не так давно изучаю ООП и PDO пишу класс для соединения с базой. Ошибки не выдает но и выборки тоже не делает. private $_db; ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru