Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 50
MySQL

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

20.01.2019, 20:16. Показов 2254. Ответов 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru