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

Запретить запись в базу, если в базе уже есть такая запись - PHP БД

15.04.2016, 08:50. Показов 3670. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Люди добрые помогите кто чем сможет. Есть запрос

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
$number = $_POST['number'];
$datetime = $_POST['datetime'];
$dept = $_POST['dept'];
$text = $_POST['text'];
$disp = $_POST['disp'];
$usrt = $_POST['usrt'];
 
$serverName = "172.28.42.19";
$connectionInfo = array( "Database"=>"test", "UID"=>"Supervisor", "PWD"=>"Supervisor");
$conn = sqlsrv_connect( $serverName, $connectionInfo );
if( $conn === false ) {
die( print_r( sqlsrv_errors(), true));
}
$sql = "INSERT INTO jOrdersJounal1 (Num, begin_dts, dept, note, disp) 
VALUES ('$number', '$datetime', '$dept', '$text', '$disp')";
 
$stmt = sqlsrv_query( $conn, $sql);
if( $stmt === true) {
die( print_r( sqlsrv_errors(), true) );
}
sqlsrv_free_stmt( $stmt);
который через форму получает данные и записывает их в бд. Как реализовать чтобы, по полю "Num"-(туда записывается номер нарушения, цифрами) был запрет записи одинаковых данных.

Добавлено через 1 час 34 минуты
простите чуть чуть, не так с формулировал вопрос, надо что бы если такие данные в поле Num уже есть то выходила бы ошибка типа "Данный номер для записи уже занят", а если таких данных нет, проходила запись данных в бд
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.04.2016, 08:50
Ответы с готовыми решениями:

Запретить запись в базу, если в базе уже есть запись
Здравствуйте уважаемые форумчане. У меня есть база данных в которую пользователи добавляют адреса сайтов Они добавляют и http://site.ru...

Проверка, есть ли такая запись в базе данных
Здравствуйте. Помогите, пожалуйста. Это сайт отеля. Есть формы ввода фамилии, даты заезда, отъезда, номер, количество человек, статус...

Процедура с условием: если такая запись есть, то update, если нет, то insert
Хочу сделать процедуру по вбиванию/удалению. Если такая запись есть, то update, если нет, то insert. Подсказали примерно такую штуку, но...

6
576 / 514 / 253
Регистрация: 26.09.2010
Сообщений: 2,603
15.04.2016, 09:21
bapmak, добавь сначала проверку на существование номера
PHP
1
2
3
$sql_chek = "SELECT `num` FROM `jOrdersJounal1` WHERE `num`= '".$number."'";
$rs_chek = sqlsrv_query( $conn, $sql);
// ну а дальше проверяем если вернул результат то ошибка если пусто то делаем вставку в БД
0
0 / 0 / 0
Регистрация: 15.04.2016
Сообщений: 8
15.04.2016, 09:29  [ТС]
А не мог бы ты поподробней расписать, я только учусь и мне отдельные строки кода трудно понимать, буду очень тебе признателен.
0
576 / 514 / 253
Регистрация: 26.09.2010
Сообщений: 2,603
15.04.2016, 09:48
Лучший ответ Сообщение было отмечено bapmak как решение

Решение

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
$number = $_POST['number'];
$datetime = $_POST['datetime'];
$dept = $_POST['dept'];
$text = $_POST['text'];
$disp = $_POST['disp'];
$usrt = $_POST['usrt'];
 
$serverName = "172.28.42.19";
$connectionInfo = array( "Database"=>"test", "UID"=>"Supervisor", "PWD"=>"Supervisor");
$conn = sqlsrv_connect( $serverName, $connectionInfo );
if( $conn === false ) {
die( print_r( sqlsrv_errors(), true));
}
 
$sql_chek = "SELECT `num` FROM `jOrdersJounal1` WHERE `num`= '".$number."'";
$rs_chek = sqlsrv_query( $conn, $sql);
$row_count = sqlsrv_num_rows( $rs_chek );
if ($row_count === false) {
echo "Такой номер существует";
}else {
$sql = "INSERT INTO jOrdersJounal1 (Num, begin_dts, dept, note, disp) 
VALUES ('$number', '$datetime', '$dept', '$text', '$disp')";
 
$stmt = sqlsrv_query( $conn, $sql);
if( $stmt === true) {
die( print_r( sqlsrv_errors(), true) );
}
sqlsrv_free_stmt( $stmt); 
}
1
0 / 0 / 0
Регистрация: 15.04.2016
Сообщений: 8
15.04.2016, 10:07  [ТС]
Спасибо тебе большое

Добавлено через 12 минут
Виталюска

Блин рано радовался, не работает, при вводе любых данных выдает "Такой номер существует";
0
576 / 514 / 253
Регистрация: 26.09.2010
Сообщений: 2,603
15.04.2016, 13:14
bapmak, посмотри правельные названия полей? название таблицы?
Цитата Сообщение от Виталюска Посмотреть сообщение
if ($row_count === false) {
замени эту строчку на
PHP
1
if ($row_count == 0) {
0
0 / 0 / 0
Регистрация: 15.04.2016
Сообщений: 8
18.04.2016, 01:40  [ТС]
Все равно работает только в одну сторону
"такой номер уже есть"
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.04.2016, 01:40
Помогаю со студенческими работами здесь

Как можно продолжить поиск записи в БД, если одна такая запись уже найдена?
Как можно продолжить поиск записи в БД, если одна такая запись уже найдена??? используя метод Find?? Заранее благодарен...

Проверить есть ли запись переданная через checkbox в базе, если есть то не заносить её
Проблема следующая. Есть форма, пользователь выбирает checkbox 1,2,10 хоть все пусть! echo "<input type='checkbox' name='lang'...

Как проверить запись на существование и добавить ее в базу данных если ее там нет или отредактировать если она там есть?
INSERT INTO AdvancedAccess VALUES('BlackBurn','test@yandex.ru','3884e9a59a96c3969c3b18d3cea442c4','1','2018-05-31 15:08:09') where ((SELECT...

Проверить есть ли такая запись в БД
Подскажите как узнать есть ли в БД уже такая запись которую я хочу добавить в БД. Вот мой код на вставку в БД. try { conn...

Как проверить, если запись есть в таблице, то вывести ошибку "Запись существует"
как проверить если запись есть в таблице (datagridview) то вывести ошибку "Запись существует", использую access Точнее: например в...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru