Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> CREATE TRIGGER, Как работает CREATE TRIGGE в MYSQL 
:(
    Опции темы
yulyaT
Дата 26.6.2012, 11:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 30.1.2012

Репутация: нет
Всего: нет



В MYSQL возможно ли создание триггера для update и insert одновременно,
т.е. если строка существует, то update иначе insert?
Если да, для понимания малюсенький пример плс???
Факи и мануалы только запутали:(
Заранее спасибо!!
PM MAIL   Вверх
Akina
Дата 26.6.2012, 13:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 454



Цитата(yulyaT @  26.6.2012,  12:03 Найти цитируемый пост)
если строка существует, то update иначе insert

Для этого существует insert ... on duplicate key update ..., не надо никаких триггеров.
Цитата(yulyaT @  26.6.2012,  12:03 Найти цитируемый пост)
Если да, для понимания малюсенький пример плс???

Код

insert into Mytable (id, val) values (100,1) on duplicate key update set val=val+1;



--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
yulyaT
Дата 26.6.2012, 14:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 30.1.2012

Репутация: нет
Всего: нет



Цитата(Akina @  26.6.2012,  13:08 Найти цитируемый пост)
insert ... on duplicate key update

Спасибо!! В MSSQL такой конструкции не было.
Сейчас почитаю...
Если есть очень простой, но РАБОТАЮЩИЙ пример триггера в MYSQL, очень хотелось бы посмотреть как это вообще делается в MYSQL.



PM MAIL   Вверх
Akina
Дата 26.6.2012, 14:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 454





--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
yulyaT
Дата 27.6.2012, 12:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 30.1.2012

Репутация: нет
Всего: нет



Код

insert into Mytable (id, val) values (100,1) on duplicate key update set val=val+1;

Не сработало у меня:(
MySQL said: Documentation
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'set val=val+1' at line 1 

Создаю таблицу
Код

CREATE TABLE `Mytable` (
  `id` int(11) DEFAULT NULL,
  `val` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci;


и пробую on duplicate key , не работает, тогда делаю так
Код

INSERT INTO `Mytable` VALUES(100, 1);

и после этого insert с on duplicate key и тоже не работает.
Что не так у меня написано?
PM MAIL   Вверх
Zloxa
Дата 27.6.2012, 12:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 33
Всего: 161



Для того чтобы on duplicate key имел хоть какой нибудь смысл, наверное, у таблицы должен быть ключ - нет?

Добавлено через 56 секунд
Но как бы там ни было, отсутствие ключа, далеко не синтаксическая ошибка


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Akina
Дата 27.6.2012, 12:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 454



Цитата(yulyaT @  27.6.2012,  13:01 Найти цитируемый пост)
You have an error in your SQL syntax; check the manual 

И что, трудно check the manual и внести необходимую корректировку?
http://dev.mysql.com/doc/refman/5.5/en/ins...-duplicate.html


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
yulyaT
Дата 27.6.2012, 13:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 30.1.2012

Репутация: нет
Всего: нет



Цитата(Akina @ 27.6.2012,  12:51)
Цитата(yulyaT @  27.6.2012,  13:01 Найти цитируемый пост)
You have an error in your SQL syntax; check the manual 

И что, трудно check the manual и внести необходимую корректировку?
http://dev.mysql.com/doc/refman/5.5/en/ins...-duplicate.html

Доверилась гуру, без set работает!!
Тем временем написала по аналогии с MSSQL без триггера и без процедуры (с этой же таблицей)
Код

if  (select count(0) as cnt from Mytable where id=100 and val=1)>0 then
       UPDATE Mytable SET val=val+1 WHERE id=100;
else 
       insert into Mytable (id, val) values (200,101);
END IF;


select * from Mytable;

на if ошибка.
И тут вилы:( 
При попытке заменить этот if на
Код

set @a = (select count(0) from Mytable where id=100 and val=1);
if  @a>0 then

Ошибка на set:(
По описанию MYSQL 5.5 declare допустимо только в процедурах:(
Внутри if нельзя select написать или у меня здесь тоже ошибка?


А как вы выкручиваетесь напр. в такой MSSQL конструкции:
Код

set @a=3;
select @a*5;


PM MAIL   Вверх
Akina
Дата 27.6.2012, 13:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 454



Код

select ... into @a ...

Мануал под рукой, подробности работы с переменными там. С примерами...


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
baldina
Дата 27.6.2012, 14:04 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3433
Регистрация: 5.12.2007
Где: Москва

Репутация: 1
Всего: 101



Цитата(yulyaT @  26.6.2012,  14:08 Найти цитируемый пост)
В MSSQL такой конструкции не было

в MSSQL есть MERGE (который, в отличие от on duplicate key, соответствует стандарту SQL)
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.0731 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.