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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Частые drop & create table 
:(
    Опции темы
Suic2
Дата 11.10.2012, 17:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Если я очень часто(раз в несколько секунд) удаляю таблицу и создаю заново это плохо? Или это никак не влияет на состояние БД и такое решение вполне жизнеспособно? 
Делаю так:
Код

START TRANSACTION;
DROP TABLE IF EXISTS dhcp_leases;
CREATE TABLE dhcp_leases(id INT NULL AUTO_INCREMENT, ip TINYTEXT, mac VARCHAR(18), starts VARCHAR(20), ends VARCHAR(20), sw_mac VARCHAR(18), sw_addr TINYTEXT, sw_port TINYINT, PRIMARY KEY (id)) ENGINE = InnoDB;
INSERT INTO dhcp_leases (ip, starts, ends, mac, sw_mac, sw_addr, sw_port) VALUES $sql
COMMIT;



Это сообщение отредактировал(а) Suic2 - 11.10.2012, 17:43
PM MAIL   Вверх
Akina
Дата 11.10.2012, 19:43 (ссылка) |   (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



А нахрена? TRUNCATE гораздо быстрее.


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

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


Чо?
****


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

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



DDL работают в транзакции?  smile 


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


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


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

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



Цитата(Zloxa @  11.10.2012,  23:13 Найти цитируемый пост)
DDL работают в транзакции?    

Угу.. правда, они фиксируют её.


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

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


Чо?
****


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

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



Цитата(Akina @  11.10.2012,  23:43 Найти цитируемый пост)
Угу.. 

Неа...  smile 
Цитата(Akina @  11.10.2012,  23:43 Найти цитируемый пост)
правда, они фиксируют её. 

Как правило, они фиксируют ее перед, потому в транзакции не работают  smile 

Это сообщение отредактировал(а) Zloxa - 12.10.2012, 09:03


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


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


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

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



Zloxa, я имел в виду, что синтаксически это не ошибка.


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

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


Новичок



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

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



Значит нет смысла в этой транзакции? Просто хотел чтобы данные были всегда доступны, а если я сначала очищу таблицу, а между её заполнением к ней поступит запрос и данных не обнаружится будет печально:(
Как в этом плане работает truncate?

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


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


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

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



Цитата(Suic2 @  12.10.2012,  10:50 Найти цитируемый пост)
Значит нет смысла в этой транзакции?

В ЭТОЙ - никакого.

Цитата(Suic2 @  12.10.2012,  10:50 Найти цитируемый пост)
если я сначала очищу таблицу, а между её заполнением к ней поступит запрос и данных не обнаружится будет печально:(

Гм... какой смысл создавать транзакцию, в принципе не понимая, что это такое?

Цитата(Suic2 @  12.10.2012,  10:50 Найти цитируемый пост)
Как в этом плане работает truncate?

Смотря какой уровень изоляции выбран...


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

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


Чо?
****


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

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



Цитата(Akina @  12.10.2012,  10:57 Найти цитируемый пост)
Смотря какой уровень изоляции выбран... 

Truncate это тоже DDL, емнип smile


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


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


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

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



Да, действительно, с версии 5.0.8 TRUNCATE TABLE тоже коммиттит изменения....


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

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


Новичок



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

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



Цитата(Akina @  12.10.2012,  09:57 Найти цитируемый пост)
Гм... какой смысл создавать транзакцию, в принципе не понимая, что это такое?

чтобы спросить на форуме и меня наставили на путь истинный smile 
извиняюсь если мой бредовый пример вас смутил
PM MAIL   Вверх
Akina
Дата 12.10.2012, 10:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Цитата(Suic2 @  12.10.2012,  11:40 Найти цитируемый пост)
чтобы спросить на форуме и меня наставили на путь истинный  

Ну на форуме это вызывает... ммм... некоторое удивление... почему бы не прочитать хотя бы основы в документации? 

Кстати... а сколько записей максимально может быть в этой таблице? а то ведь delete from dhcp_leases на небольшой таблице будет достаточно быстрым (особенно если её на Memory Engine)...


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

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


Новичок



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

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



10-20 тысяч
PM MAIL   Вверх
Akina
Дата 12.10.2012, 10:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



И что, изменений настолько много, что дешевле грохнуть и пересоздать? не понимаю...


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

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


Чо?
****


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

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



Цитата(Suic2 @  12.10.2012,  10:50 Найти цитируемый пост)
Просто хотел чтобы данные были всегда доступны, а если я сначала очищу таблицу, а между её заполнением к ней поступит запрос и данных не обнаружится будет печально:(

Здесь все зависит от уровня изоляции транзакции в котором работает читающая сессия.
Вы знаете в каком она работает? Можете как-то повлиять на уровень ее изоляции? 

Если читающая сессия работает в read uncommited, и вы не можете этого изменить, ваши попытки тщетны.
Если читающая сессия рабоатет в read commited - detete / insert в помощь

Если честно, затруднился бы ответить что прочитает MySQL сессия, читающая в repeatable read, serializable после truncate в другой сессии. Скорее всего ожидания не оправдаются. Транкейт рассогласует чужую транзакцию. Хорошо если эксепшн поднимится, но зная о "дружелюбности" MySQL к пользователю, думаю - врядли.

Оракл вот перед транкейтом пассует. Тоже с-ка эксепшна не поднимает.
Сессия 1
Код

SQL> create table test as select 1 val from dual;
 
Table created
SQL> set transaction isolation level serializable;
 
Transaction set
SQL> select * from test;
 
       VAL
----------
         1

Сессия 2
Код

SQL> delete from test;
 
1 row deleted
SQL> commit;
 
Commit complete
SQL> select count(*) from test;
 
  COUNT(*)
----------
         0
 

сессия 1
Код

SQL> select * from test;
 
       VAL
----------
         1
 

сессия 2
Код

SQL> truncate table test;
 
Table truncated
 

сессия 1
Код

SQL> select count(*) from test;
 
  COUNT(*)
----------
         0
 


Это сообщение отредактировал(а) Zloxa - 12.10.2012, 11:08


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




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


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

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