Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
1 / 1 / 1
Регистрация: 25.09.2015
Сообщений: 28

Заблокировать запись

09.06.2017, 22:43. Показов 1049. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!

Пол дня читаю про блокировки, но пока нормально не получается сделать (

MYSQL InnoDB

Есть запрос который выдает ip (таблица sockstable), из тех которые сейчас не в онлайне (таблица onlinesocks)

SELECT sockstable.ip FROM sockstable WHERE sockstable.ip NOT IN (SELECT onlinesocks.online FROM onlinesocks) limit 1

После чего этот ip добавляется в таблицу онлайн (onlinesocks)

INSERT INTO onlinesocks (online) VALUES ("'+ip+'")

Проблема что с базой работает много клиентов, и они мешают друг другу, несколько успевают сделать запрос Select и добавить в onlinesocks.

Как заблокировать запись для чтения? И разблокировать её после INSERT.
Желательно что бы при SELECT её даже не видно было, что бы клиент брал следующий ip который не онлайн.

Придумал такой запрос, но проблема что не могу узнать какой ip он выбрал... sockstable.ip как то можно получить из этого запроса?

INSERT INTO onlinesocks (online) SELECT sockstable.ip FROM sockstable WHERE sockstable.ip NOT IN (SELECT onlinesocks.online FROM onlinesocks) limit 1
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.06.2017, 22:43
Ответы с готовыми решениями:

Заблокировать учетную запись
Добрый день Подскажите почему не активно поле "Заблокировать учетную запись"

Заблокировать запись на флеш накопитель
Не знаю в какой раздел лучше отнести данную тему. Состоит вопрос в чем. Нужно написать некую программу при помощи которой можно отслеживать...

Как заблокировать диск на запись
Ребят, подскажите, можно ли как-то заблокировать запись на диск без использования ntfs прав? Иногда надо разрешать запись. Внешние боксы...

6
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
10.06.2017, 01:17
может ещё (кроме ip) поля нужны в online? чтобы знать какому клиенту он достался?
0
1 / 1 / 1
Регистрация: 25.09.2015
Сообщений: 28
10.06.2017, 16:38  [ТС]
Цитата Сообщение от YuryK Посмотреть сообщение
может ещё (кроме ip) поля нужны в online? чтобы знать какому клиенту он достался?
Это тут причем?) Никак на блокировку не влияет... ключевые поля счетчики везде есть...

Использовал FOR UPDATE , работает хоть и кривовато, бывает успевают 2 потока проскочить... не пойму почему...
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
10.06.2017, 16:55
т.е. в onlinesocks есть ещё и счетчик? ну так LAST_INSERT_ID() вам не поможет?
0
1 / 1 / 1
Регистрация: 25.09.2015
Сообщений: 28
10.06.2017, 17:05  [ТС]
Цитата Сообщение от YuryK Посмотреть сообщение
т.е. в onlinesocks есть ещё и счетчик? ну так LAST_INSERT_ID() вам не поможет?
Поможет, не знал что есть такая функция.... Всю ночь с FOR UPDATE промучался... с костылями более менее заставил работать правильно... спасибо, будет как запасной вариант...
0
1 / 1 / 1
Регистрация: 25.09.2015
Сообщений: 28
12.06.2017, 22:06  [ТС]
Блокировки все таки глючено работают, использовал LAST_INSERT_ID без блокировок. Теперь проблема что загружены все 8 ядер процессора сервера, при многопоточной работе...
Можно ли оптимизировать запрос, что бы хоть как то уменьшить нагрузку на процессор?

MySQL
1
2
3
INSERT INTO onlinesocks (online) SELECT sockstable.ip FROM sockstable WHERE sockstable.ip NOT IN (SELECT onlinesocks.online FROM onlinesocks) limit 1
SET @lastID := LAST_INSERT_ID()
select online from onlinesocks where id=@lastID
Добавлено через 1 час 20 минут
всего по около 3000 записей в sockstable и onlinesocks... почему такие тормоза? 8 ядер перегружены (

Добавлено через 6 минут
всего лишь нужно найти запись в таблице, которой нет в другой таблице, и добавить её в неё.... И такая команда полностью загружает одно ядро, делается больше 2 секунд.... Да на любом языке программирования это будет выполнятся намного меньше секунды... Может MySql как то настроить можно? уже менял количество потоков и т.д.... не пойму почему так тормозит...
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
12.06.2017, 23:32
индексы по online в обеих таблицах есть? Иначе для вставки одной записи потребуется просканировать обе таблицы полностью.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.06.2017, 23:32
Помогаю со студенческими работами здесь

Заблокировать учетную запись в определённое время
Здравствуйте. Нужно заблокировать учетную запись в конкретное время (например, в 12:00 сегодняшнего дня). Порылась в мане usermod и passwd,...

Как грамотно заблокировать запись в ADO?
RS.LockType = adLockPessimistic В MSDN пишут, что при правке запись блокируется автоматически и выдумывать ничего не надо. Предположим...

Четыре кнопки на форме: добавить запись, удалить запись, закрыть, найти запись
Private Sub КнопкаДобавитьЗапись_Click() On Error GoTo Err_КнопкаДобавитьЗапись_Click DoCmd.GoToRecord , , acNewRec ...

Заблокировать по IP
В общем проблема в следующем мне нужно заблокировать по IP голосовалку в битриксе прописываю этот код он блокирует голосовалку но так же...

Заблокировать клавиатуру
Всем привет) Есть необходимость заблокировать клавиатуру, по типу blockInput, но чтоб мышь(тачпад) при этом была активна. Кто может...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru