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

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

14.10.2014, 11:23. Показов 12131. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru