Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/13: Рейтинг темы: голосов - 13, средняя оценка - 4.85
4 / 4 / 0
Регистрация: 15.06.2011
Сообщений: 75

Триггеры

22.10.2013, 17:40. Показов 2468. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! База данных называется "mybd" Есть таблица "Заказы" с полями код_клиента, фио_клиента, код_номера, дата_заезда, дата_выезда. Необходимо написать такой триггер, чтобы в поле дата_заезда автоматически записывалась текущая дата. Кое-что я нацарапала, но я не знаю верно это или нет. С MySQL столкнулась впервые, преподаватель в нём ни бум-бум, а задание сдать надо. И еще, я работаю в MySQL Server 5.6 Workbench. Триггеры к базе надо добавлять через Add Routine? У меня не получается это сделать, почему-то мои карябки-марябки самостоятельно стираются программой.
MySQL
1
2
3
4
5
6
7
DELIMITER $$
CREATE trigger `mybd`.`Заказы` BEFORE INSERT
    ON `mybd`.`Заказы`
    FOR EACH ROW BEGIN
      SET NEW.`дата_заезда` = NOW();
    END$$ 
DELIMITER ;
И второй триггер нужно ещё сделать, например, чтобы проверял дата_заезда<дата_выезда. как это сделать, я не очень понимаю к сожалению. Толкните в нужное русло пожалуйста.

Добавлено через 48 минут
Может второй триггер можно вот так реализовать?
MySQL
1
2
3
4
5
6
7
CREATE TRIGGER `mybd`.`Заказы` BEFORE INSERT
ON Заказы
for each row 
BEGIN
IF new.дата_заезда>new.дата_выезда THEN PRINT ‘Дата заезда не может быть больше даты выезда’;
END IF;
END
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
22.10.2013, 17:40
Ответы с готовыми решениями:

Триггеры
Всем здрасте.Проблема:

Триггеры
Доброго времени суток. Есть проблема с триггером. Задание такое: разработать триггер на добавление записей к таблице, такой, чтобы...

Триггеры
Как сделать в MYSQL, 2 триггера (на добавление и удаление).

4
9 / 9 / 0
Регистрация: 26.02.2010
Сообщений: 165
25.10.2013, 14:46
есть поле TIMESTAMP поставьте там значение DEFAULT CURRENT_TIMESTAMP

вот пример

SQL
1
2
3
CREATE TABLE t1 (
  ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP 
);
он создаст поле ts и при создании записи дата будет автоматически записываться NOW()

если же Вам нужно при обновлении записи писать дату и время то

SQL
1
2
3
CREATE TABLE t1 (
  ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);
1
4 / 4 / 0
Регистрация: 15.06.2011
Сообщений: 75
25.10.2013, 19:02  [ТС]
Спасибо большое, но мне нужно именно триггерами сделать. Или ваш вариант тоже является триггером?
0
9 / 9 / 0
Регистрация: 26.02.2010
Сообщений: 165
25.10.2013, 19:16
нет мой не триггер.

первый поменяйте BEFORE на AFTER
1
4 / 4 / 0
Регистрация: 15.06.2011
Сообщений: 75
25.10.2013, 22:39  [ТС]
Спасибо большое вам!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.10.2013, 22:39
Помогаю со студенческими работами здесь

Триггеры
Доброго дня! Люди, вопрос есть: вот я создаю триггер на вставку в таблицу refersto имени экзамена examName при вставке экзамена в таблицу...

Триггеры
Всем привет =) Нужен триггер, которы либо AFTER либо BEFORE INSERT в табицу `test` осуществляет запись в таблицу `log` ...

Триггеры в MySQL
Здравствуйте уважаемые знатоки, и тем, кому в кайф помогать другим) Задачка у меня простенькая, есть табличка для техподдержки. Когда...

Для чего используются триггеры?
одна таблица содержит количество рабочих. вторая таблица содержит инфу о рабочих. если ко второй будем добавлять поле или удалять, то...

Mysql триггеры, добавление строки в ту же таблицу
ПРошу помочь в следующем: где подвох? ошибка выскакивает в версии 5.5 при попытке создать следующий триггер: CREATE OR REPLACE...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru