Архив: Скрипт-обработчик БД (работ с базой MODx)

Бюджет 8$ / 500
руб
в месяц
Создан: 6 лет назад
Закрыт
Описание
- В modx каждый ресурс это товар. В ТВ хранятся параметры, остатки и цены. 
- Нужно сделать скрипт, можно запускать вне модх, главное что бы он работал адекватно и правильно. Можно было бы запускать по крон, но обновление сайта происходит не по расписанию, а когда человек начал эту работу. Поэтому требуется ручной запуск, удобный, и рабочий!
- ресурсов около 50 тыс, параметров тв около миллиона, обрабатывать конечно надо не все, ресурсов около 5 тыс
- Нужно сравнение старого и нового остатка для товаров в наличии, и если остаток изменился, то в другое поле завести дату и число остатка на эту дату, если нет изменений то ничего не делаем. 
- Работы то на час

Подробнее опишу на основе sql запросов:
1) Получаем список товаров из таблицы ресурсов, по которым нужно делать сравнение остатка:
SELECT `id` FROM `site_content` WHERE `template` = 2 AND `publishedon` > 1570870780
publishedon= дата измененного товара, нужно выбрать измененный в течение 7 последних дней (на всякий случай значение за последние сколько дней, нужно что бы можно было менять в самом скрипте вручную), дата хранится в формате unix

2) В таблице хранения параметров ищем остатки прошлые и новые. 
SELECT `value` FROM `site_tmplvar_contentvalues` WHERE `tmplvarid` = 143 AND `contentid` = 23975; 
т.е. в таблице параметров ищем новый остаток товара, `tmplvarid` = 143 это id параметра с новым остатком, `contentid` = 23975 id товара из первой таблицы

SELECT `value` FROM `site_tmplvar_contentvalues` WHERE `tmplvarid` = 41 AND `contentid` = 23975; 
аналогично, но ищем прошлый остаток, соответственно `tmplvarid` = 41 это id параметра с прошлым остатком
если такой записи нет, то создаем ее (например товар новый и соответственно прошлого остатка нет)

3) Далее их сравниваем, если они разные то
а) заменяем в прошлый остатке на новый  (например стало 3 единицы товара)
UPDATE `site_tmplvar_contentvalues` SET `value`="3" WHERE `tmplvarid`="41" AND `contentid` = 23975; 

б) дописываем в историю изменения остатков текущее изменение, 
SELECT `value` FROM `site_tmplvar_contentvalues` WHERE `tmplvarid` = 176 AND `contentid` = 23975; 
т.е. берем историю изменения остатков, к значению в начале добавляем (если такой записи нет, то создаем ее (например товар новый и соответственно прошлого остатка нет)
в таком формате "ДД.ММ = остаток новый <br"
например
-----
18.10 = 3<br
15.10 = 10<br
14.10 = 0<br
10.10 = 7<br
19.09 = 2<br
14.09 = 5<br
----

в) смотрим если история имеет более 15 тегов 
то удаляем с конца до второго <br, т.е. что бы не хранилось слишком много информации, а только об 15ти последних изменениях.

г) Далее обновленную историю записываем обратно:
UPDATE `site_tmplvar_contentvalues` SET `value`="18.10 = 3<br15.10 = 10<br14.10 = 0<br10.10 = 7<br19.09 = 2<br14.09 = 5
" WHERE `tmplvarid`="176";
если товар новый, то создаем запись
Категория

Похожие проекты

$3
0 0
расшифровать или подобрать MD5 Хэш: c74d673f4042bd732ae2a287c059a9ba. начало ответа 8385626820 8385626820. хх....
3 недели назад
safe 
0 0
Cофт для автоматической торговли токенами в сети Solana. На разработку с тестами и устранением багов выделяется 1-2 месяца, при превышении контракт расторгается!...
safe 
0 5
Необходимо разработать систему, которая: Подключается к API Diagnocat и iDent (через токены доступа). Получает данные о пациенте, результатах диагностики, снимках и назначениях. Автоматически формирует структурированный отчет по шаблону (включая врачей, этапы лечения, стоимость и описание процедур).......
 
0 0
Необходимо связать БД 1C:ERP с БД Outlook, MS Access, Битрикс24. Например при вводе нового сотрудника в 1С:ERP он должен автоматически появляться в вышеперечисленных БД....
5 месяцев назад
 
0 1
Требуется реализация отчёта на кастомизированной 1С:УПП 1. 2, ТЗ и контрольный пример во вложении, 80% кода должно быть покрыто модульными тестами....
5 месяцев назад
$7
0 2
Мне нужно копировать мой текст и вставлять в одну группу ВК с открытой стеной для публикации рекламы. Задача скрипта/сервиса/программы - примерно каждые 10 секунд брать мой текст и вставлять в эту группу. Я пробовал через одну программу, которая записывает действия мышки и потом повторяет, но она как-то......
7 месяцев назад
safe 
0 0
Написать прошивку для A94B114, используя 2 подобные рабочие прошивки. Все файлы есть....
$21
0 2
Нужно разархивировать файл архив. ujems, есть распаковщик, но выдает ошибку. Прислать пруфы(скрины)....
10 месяцев назад
safe 
0 1
Входные: Имеется скрипт по обработке email писем и добавление их в систему Redmine   Проблема: Система обработки этих писем написана некорректная и негибкая    Задача: Переписать логику обработки входящих писем, чтобы исключить их потерю при незначительных отклонениях от ожидаемой структуры....
$37
0 2
- В обязанности сотрудника входит поддержание мобильного приложения системы автоматизации бизнеса. - Работа сдельная: задачи выдаются на оценку, далее после согласования передаются на реализацию. - Заключаем договор и NDA (соглашение о неразглашении)....
$71
0 0
Информация о проекте: Проект включает в себя React Native приложение с Expo внутри которого находится webview с сайтом На устройствах с ОС IOS проблема с воспроизведением видео....
10 месяцев назад
safe 
0 0
Разрабатываю десктопные программы на языке Java,  а так же Java + SQL....
 
0 7
  1. Чтобы можно было писать описание события (без заголовка) - превью в списке берется N количества букв с начала. (в списке писать дату события и сколько осталось до него) . Выставление даты и времени напоминания и ИНТЕРВАЛА ПОВТОРА ОТ 1 МИНУТЫ! Выставлять количество повторов, далее напоминания прекращаются.......
safe 
0 5
Сайт arg2028t. beget. tech/. Нужно сделать вот такой калькулятор. airprint. by/outdoor/wide-format. и еще некоторые доработки....
safe 
0 9
Краткое описание: Мы ищем исполнителя для тестирования функционала мобильного приложения на платформе Android. Задача включает проверку основных функций приложения, таких как работа комнаты, передача видео, звука и чата, а также создание подробной отчетности о найденных ошибках.   Требования к исполнителю:......
safe 
0 12
Разработка чат-бота под ваши нужды....
$143
0 1
Oпpocы (1008pyб/чaс) Заходитe на сaйт: gonsù....
1 год назад
 
0 4
Требуется создать скрипт для premiere pro. Данная суть скрипта: в выделеном бине нужно что бы автоматически проставлялся in out ровно по серидине файла так что бы выделенная область была длиной 3 секунды. И требуется кнопка что бы работало через окно expressions. Проблема текущего в том что он не работает......
 
0 2
Нужно создать приложения под гемблинг/беттинг, на котлин. Приложение должно работать Firebase. Детали вышлю при обсуждение....
Смотреть все