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

Проверка на наличие элемента в БД mysql

14.10.2014, 11:23. Показов 12066. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Необходимо сделать проверку введенного пользователем элемента в форму на нахождение его в базе данных. К сожалению прочтение имеющихся тем на форуме не помогли, так как в mysql не силен.

Собственно создана база данных ..._authenticity в ней таблица secretnumber и введены строки содержащие одно значение, вида a0000000.

Форма в которую пользователь вводит это значение:
HTML5
1
2
3
4
<form action="authenticity.php">
<p><input type="text"required maxlength="8" pattern="[a-z][0-9]{7}" placeholder="введите 8 символьный код" /> 
<input class="button" type="submit" value="ПРОВЕРИТЬ" /></p>
</form>
Подскажите пожалуйста правильный код, который должен находиться в authenticity.php, если можно с пояснениями какая функция за что отвечает:
PHP
1
2
3
4
5
 <?php
$conn = mysql_connect('localhost','root','password');
mysql_select_db('..._authenticity');
???
?>
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.10.2014, 11:23
Ответы с готовыми решениями:

Проверка на наличие полей в MySQL
Приветствую. Заказчик поставил задачу: Отображать на сайте последние просмотренные объекты. Мое решение: Каждый раз, когда...

Проверка формы "на лету" на наличие вводимого логина в MySQL
Хочу реализовать следующее: пользователь при регистрации вводит логин, и форма сразу проверяет, существует данный логин в БД или нет, на...

Постоянная проверка на наличие элемента
Вот такой вопрос, как сделать на Ajax сайте постоянную проверку на наличие div Блока, и если блок найден выполнить то-то действие, а если...

6
 Аватар для Vas-e-na
420 / 417 / 79
Регистрация: 21.06.2010
Сообщений: 1,362
14.10.2014, 17:30
SQL
1
SELECT COUNT(*) AS 'count' FROM `secretnumber` WHERE `имя_столбца`='%проверяемое значение из формы%'
И если count будет больше нуля то есть значение, нуль - нет.
Вам в помощь:
mysql_query
mysql_result
Этого должно хватить
0
0 / 0 / 0
Регистрация: 28.11.2012
Сообщений: 22
22.10.2014, 19:34  [ТС]
Код формы

HTML5
1
2
3
<form action="authenticity.php">
<p><input name="productnumber" type="text"required maxlength="8" pattern="[a-z][0-9]{7}" placeholder="введите 8 символьный код" /> 
<input class="button" type="submit" value="ПРОВЕРИТЬ" /></p>
Код authenticity.php

PHP
1
2
3
4
5
6
7
8
9
10
11
12
 <?php
$conn = mysql_connect('localhost','root','password');
mysql_select_db('..._authenticity')$query = "SELECT COUNT(*) FROM `secretnumber` WHERE `productnumber` = '%productnumber%'";
$result = mysql_query($query);
if (mysql_num_rows($result)>0)
    {
    echo "Да";
    }
    else
    {
    echo "Нет";
    } ?>
Почему то всегда выдает "ДА", даже при вводе не правильного кода... С командой count не нашел как ее правильно применять, помогите пожалуйста разобраться.
0
71 / 71 / 13
Регистрация: 01.09.2011
Сообщений: 379
23.10.2014, 01:25
Цитата Сообщение от Vas-e-na Посмотреть сообщение
Вам в помощь:
mysql_query
mysql_result
Ну во-первых это плохой совет, так как это устаревшие функции, лучше использовать аналоги mysqli или
если хотите быть ближе к современным подходам посмотрите PDO.
Во-вторых зачем там проценты? Мне известно использование знака % только в запросах вида:
SQL
1
WHERE some_field LIKE '%someText%'
или подобных.
В-третьих если нужно узнать только существование записи то оптимальней будет запрос с EXISTS
PHP
1
2
3
4
5
6
7
$PDO = new PDO('mysql:dbname=admin_ibanking', 'root', '');
$result = $PDO->query(
            sprintf(
                'SELECT EXISTS (SELECT * FROM secretnumber WHERE productnumber = %s) is_exist', $productNumber 
                     )
                 )->fetchObject();
echo ($result->is_exist) ? 'Yes' : 'NO';
Ну там проверки еще добавьте разные.
Вот почитайте http://php.net/manual/ru/book.pdo.php
0
 Аватар для Vas-e-na
420 / 417 / 79
Регистрация: 21.06.2010
Сообщений: 1,362
27.10.2014, 15:58
Цитата Сообщение от zebulun Посмотреть сообщение
Ну во-первых это плохой совет, так как это устаревшие функции, лучше использовать аналоги mysqli или
если хотите быть ближе к современным подходам посмотрите PDO.
Спорить не будем что лучше, я просто обрисовывал смысл
Цитата Сообщение от zebulun Посмотреть сообщение
Во-вторых зачем там проценты? Мне известно использование знака % только в запросах вида:
Ну некорректно я выбрал ограничитель, не суть...

Ну и к третьему, Вы считаете что вложенный запрос быстреее чем COUNT ???

gea, что касается Вас:
Цитата Сообщение от gea Посмотреть сообщение
%productnumber%
Тут должно быть значение, должно быть похоже на $_GET['productnumber'] (Не забудьте про экранирование)
Так в принципе верно, но при COUNT использовать mysql_num_rows глупо, т.к. всегда будет один, поэтому воспользуйтесь mysql_result($result, 0, 0)>0;
0
71 / 71 / 13
Регистрация: 01.09.2011
Сообщений: 379
27.10.2014, 17:42
Цитата Сообщение от Vas-e-na Посмотреть сообщение
Ну и к третьему, Вы считаете что вложенный запрос быстреее чем COUNT ???
Да, быстрее, это не вложенный запрос, это просто синтаксис с двумя select`ми. А быстрее, потому что запрос с exists найдет первую подходящую запись и вернет 1, count просматривает всю таблицу.
0
 Аватар для Enzzio
72 / 30 / 4
Регистрация: 29.05.2010
Сообщений: 478
17.07.2018, 18:51
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
try
            {
                echo ' :OK: ';
                $sql = "SELECT id FROM ".$table." WHERE ".$col." = ''";
                $s = $pdo->prepare($sql);
                $s->bindValue(':value', $value);
                verifyVarDump($s, '$s: ');
                $s->execute();
                
                
                
                foreach($s as $row)
                {
                    if(!isset($row['id']))
                    {
                        $valuesUnique[] = $value;
                    }
                }
            }
            catch(PDOException $e)
            {
                echo 'Не удалось читать БД';
                exit();
            }
До foreach дело не доходит, исключение не бросает. Что я делаю не так? Имя таблицы имеет жёсткий проблел. Копировал из вардампа запрос, phpmyadmin кушает. И как упростить проверку, что значение уже есть в таблице?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.07.2018, 18:51
Помогаю со студенческими работами здесь

Проверка на наличие элемента в массиве
string stroka = richTextBox1.Lines; string words = stroka.Split(' '); string a1=words; string a2=words; //и др. //Как...

Проверка на наличие элемента в массиве
&lt;?php $key = '32599F1BB332CE522EB3797474159AED'; $userid = 'NUMBER_KEY'; $url =...

Проверка списка на наличие элемента
Дано 2 списка x и y, проверить содержит ли он число 2, вывести список, если содержит. Если не содержит, то вывести &quot;Список не содержит...

Проверка таблицы на наличие элемента
Вношу измененения в одну таблицу. Мне нужно по одному полю проверить наличие данного Элемента в другой таблице... Пример: Таблица 1: ...

Проверка массива на наличие элемента
Здравствуйте.Возникла такая проблемка нужно проверить если определенное число в массиве хоть вопрос вроде и простой но у меня нечего не...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
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 - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru