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

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

15.04.2016, 08:50. Показов 3657. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru