0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 50
MySQL

Проверка актуальности данных в БД на стороне клиента

20.01.2019, 20:16. Показов 2276. Ответов 3

Студворк — интернет-сервис помощи студентам
!!!ОсторожноМногоБукв!!!
Всем привет. Ситуация такая: есть БД, допустим в ней есть таблица "Test" с n-ым кол-вом столбцов и строк в них.
Так же есть web страница, на которой существует таблица, в которую при загрузке страницы подгружается вся инфа из БД.

И так на нашей странице с таблицей за разными ПК работают всеми любимые Пупа и Лупа. Пупа зашёл на страницу, посмотрел информацию в таблице и пошёл наливать кофе. В свою очередь Лупа зашёл туда же, но в место того чтобы пойти наливать чай, он изменил данные в таблице во второй стоке, удалил четвёртую и пятую и хваля себя вышел со страницы.
Напившись кофе, Пупа подумал, что надо бы поработать. Он сел за стол и увидел, что начальство просит его распечатать отчёт по данным в таблице. Но из-за Лупы то есть из-за того, что у Пупы страница уже была ранее загружена и он не обновил её , данные в таблице остались неактуальны (неверные) и отчёт у Пупы получился неверным.

Так вот, к чему я всё это. Как избежать данного рода ситуации, ведь при работе с информацией большого кол-ва человек проблема с неактуальностью данных должна быть довольно популярная и её решений должно быть множество, но у меня найти его не вышло.

Есть пару идей но мне бы, что нибудь действенное и оптимальное.

Вариант 1: Изобрести костыль, который будет взаимодействовать с логом вида
XML
1
<user login='Лупа' tableName='Test' time='h:mm:ss' action='delete'> Удалил данные такие-то </user>
и после любого действия пользователя проверять, были ли совершены какие либо действия за определённый промежуток времени в этой таблице, если да то обновляем таблицу. Ну это такой себе вариант если честно.

Вариант 2: Это использовать что-то из функций Ajax и jQuery или тот же Prototype для проверки данных на сервере с данными у клиента и выполнения манипуляций с ними. Но какие функции точно использовать не знаю.

Вариант 3: Сделать таймер по истечению которого будут считываться данные с сервера и переноситься на клиентскую сторону без обновления страницы. У Prototype, jQuery есть такая возможность, но вопрос в другом, как это грамотно реализовать, чтобы работая с большими объёмами данных сервер попросту не лёг. Думаю что можно посмотреть в сторону многопоточности

Вариант 4: Я точно не уверен, но думаю что у DataTables тоже есть способы справиться с этим.

Собственно я свои идеи изложил и жду вашей помощи и идей, как решить проблему с неактуальностью данных на стороне клиента.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.01.2019, 20:16
Ответы с готовыми решениями:

Проверка введенных в форму данных на стороне клиента
Всем привет! У меня примитивный вопрос, но ответ хотелосьбы услышать. в общем, следующее. Я хочу организовать проверку введенных в...

Поддержка актуальности данных в таблица на стороне клиентов
Задача: С БД работает несколько операторов. Необходимо поддерживать актуальность данных в справочниках, а именно, если 1-й оператор...

Паника. Проверка даных на стороне клиента
Доброго времени суток уважаемые форумчане. То ли я чего-то не понимаю, то ли все не так хорошо. Допустим имеется документ с формой: ...

3
576 / 514 / 253
Регистрация: 26.09.2010
Сообщений: 2,603
20.01.2019, 22:56
Natanchik, при распечатке данных создавать PDF и туда грузить актуальные данные из БД, ну а на странице можно используя AJAX через определенное время перезагружать данные.
0
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 50
20.01.2019, 23:54  [ТС]
Виталюска, мне не обязательно при распечатке, мне надо просто решить проблему с тем, что пользователь может пытаться выполнять действия с данными, который другой пользователь уже удалил или изменил и тд.
Если я буду перезагружать данные раз в 30-60 секунд у 10+ людей, это же довольно большая нагрузка будет на сервер не так-ли? И раз уж на то пошло, не могли бы вы скинуть мне какой нибудь пример или саму функцию?
0
576 / 514 / 253
Регистрация: 26.09.2010
Сообщений: 2,603
24.01.2019, 13:39
Цитата Сообщение от Natanchik Посмотреть сообщение
Если я буду перезагружать данные раз в 30-60 секунд у 10+ людей, это же довольно большая нагрузка будет на сервер не так-ли?
Смотря сколько информации хранится в БД, если у Вас в БД например +100500 записей, то зачем грузить их все? а если делать какие то изменения с данными надо проверить есть ли они в БД и загружать актуальные данные из БД для работы с ними, а не те что Вы видите на странице. Например нажимаем на кнопку изменить -> делаем запрос на извлечение данных по ид -> выводим форму для изменения.
если удаление -> то проверяем есть ли запись в БД, если есть удаляем, а если нет то выводим сообщение что запись уже удалена

ну а для перезагрузки страницы используйте стандартные JS функции, если без перезагрузки то AJAX, но думаю это не лучший вариант с перезагрузкой данных, так как при работе будет мешать постоянное мелькание
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.01.2019, 13:39
Помогаю со студенческими работами здесь

Проверка правильности заполнения формы на стороне клиента
Здравствуйте помогите написать код и вставить его в эту форму для проверки правильности заполнения формы на Javascript(на свой вкус) . ...

Почему не работает проверка перед отправкой? На стороне клиента
Добрый день! Подскажите пожалуйста, почему не работает проверка, заполнено поле или нет перед отправкой данных на сервер? Вот такая...

Проверка формы на стороне клиента с использованием Parsley.js с PHP Ajax
Добрый вечер Проверка формы на стороне клиента с использованием Parsley.js с PHP Ajax Можете мне чайнику, построчно...

Хранение данных на стороне клиента. LocalStorage
Друзья, подскажите, что не так в моем коде? Захожу на страницу, а изменяет только цвет текста. Соответственно что-то с синтаксисом. Не...

Выгрузка данных в Excel на стороне клиента
Здравствуйте. Подскажите пожалуйста как выгружать данные из бд в excel таким образом, чтобы документ excel создавался на машине клиента,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru