Владимир Белов: написал:
Теперь у меня есть хобби - в свободное время пытаюсь запустить vogbit на новом компьютере. Базу данных удалял потому что восстано ...
Константин Чилингаров: Здравствуйте,
Сделать реально.
Есть API. Можно из внешнего приложения законнектиться к базе данных VOGBIT и в нужный момент вытащить нужну ...
Константин Чилингаров: Здравствуйте,
Да, можно так сделать.
Шаблон отчёта нужно соответствующий настроить.
Пришлите, пожалуйста, на почту, какие этикетки дол ...
Константин Чилингаров: Здравствуйте,
Дело в том, что демо-пример "/support/19454/ Движение заказа " сделан полностью на "/articles/5286/ среднем " уровне, и в данном ...
Константин Чилингаров: Здравствуйте,
Существуют задания для производства, которые ссылаются на эту операцию (на основе неё созданные). Они не дают удалить опе ...
Константин Чилингаров: Здравствуйте,
написал:
После первой установки все работало нормально и где то через месяц работы все поломалось.
Обновление ОС пост ...
Константин Чилингаров: В целом, проблема понятна.
Будем думать, конечно, как улучшить. По мере наличия времени.
К сожалению, не получается всем одновременно зан ...
Константин Чилингаров: Здравствуйте,
написал:
Хотим почистить базу для того что бы ускорить работу Вогбит, есть много позиций в номенклатуре, которые...
Име ...
Константин Чилингаров: Здравствуйте!
написал:
При открывании статистики появляется окно ошибки см.скрин
Это где-то в задании один и тот же работник указан 2 ...
Константин Чилингаров: Небольшой совет по теме:
Никогда не храните созданные файлы резервных копий базы данных там же (на том же компьютере/диске), где и сама ...
Константин Чилингаров: Поскольку этот старый модуль считает долго, там технология была такая:
Расчёт выполнялся на какой-то момент времени. На актуальных на эт ...
Как-то хреновенько работает Удаление заданий. Почти в каждом первом случае возникает ошибка (см. скриншот). Хотя если один или несколько раз повторить процедуру то обработка иногда доходит до конца, иногда нет, но заказ все таки очищается и удаляется.
И еще, закрытие окна ошибки почти всегда приводит к сворачиванию окна всей программы. О групповой обработке не может быть и речи. В общем одни мучения.
И еще, при очистке одного заказа появляется ошибка про какие-то ссылающиеся вложения. Пошарил, но ничего связанного не нашел.
Я в августе чистил базу данных одного из наших пользователей. Удалил этой утилитой примерно 115 000 заданий.
Не сказать, что "с пол пинка". Удалял частями. Пару раз были сбои, перезапускал. Но непонятно из-за чего, я на ночь оставлял удаляться. Может с сетью проблема какая-то была, может ещё что. К тому же, я использовал в качестве сервера довольно старый компьютер с посредственным процессором и 4G RAM. Так себе, прямо скажем, вариант для таких объёмов
Но, в целом, и мучений каких-то особых не испытал. Всё удалил успешно в итоге.
ссылку на базу отправил на почту. попробуйте удалять заказы с начала 2013 года. у меня в каждом по 1-5 остановой с ошибкой. 300 заказов в год замучаюсь чистить таким образом.
Разобрались. По поводу ошибок - наша недоработка. Утилита изначально была настроена под "высокий" уровень учёта. И не учитывала один нюанс, который есть на "максимальном". Из-за этого были ошибки. Подождите пока немного, не удаляйте задания. Сейчас попробуем починить. Проверим, выложу обновлённую версию утилиты.
По поводу "вложений": Карта заказа "370 Лафортецца" приделана в качестве вложения к сообщению. Сообщение можно найти в папке Inbox у пользователя "Сковпень". При удалении соответствующее сообщение попадает в папку Deleted objects у того же пользователя. Поэтому для окончательного удаления надо удалить сообщение из "входящих", а потом из "удалённых".
Остаются "задания" некоторые. Ни к чему не привязанные уже, но и не удалённые. Не смертельно, но и не очень здорово. Подождите, пожалуйста, пока больше не удаляйте. Мы собрали уже новую версию утилиты, надо только проверить её ещё.
Получил, запустил. Задания удаляет без ошибок. Заказы удалил, расписания удалил. НО, в заданиях куча записей за весь удаленный год. Остальное объяснить сложно. Посмотрите скриншоты. Так и должно быть?
Если можете взять бэкап до неудачных экспериментов с удалением, то возьмите его. И удалите корректно все задания, заказы и т.п.
Если не можете, то надо чистить базу теперь от последствия неудачных попыток удаления.
Для начала, например, можно сделать вот что:
1. Создать тестовый заказ с 1 позицией в нём 2. Открыть получившуюся карту заказа в режиме Компоненты. Встать на единственный компонент, открыть для него зависимое окно Задания. 3. Скопировать из справочника Задания все "потерянные" задания типа "Задание на участок", которые остались в справочнике. Вставить их в открытое в п.2 окно Задания для компонента карты заказов. Тип связи использовать "Задание на участок".
Тем самым мы приделываем потерянные "задания на участок" к позиции своего тестового заказа.
Потом натравить на этот тестовый заказ утилиту "Удаление заданий".
Я бы сделал так в качестве первого шага (он точно не единственный, потом придётся по аналогии делать чуть-чуть другую тестовую структуру для удаления "потерявшихся" заданий на посты).
Предварительно, прежде чем всем этим заниматься, естественно, нужно сделать бэкап базы в её текущем состоянии. На всякий случай.
Я вернулся к состоянию базы до запуска исправленной удалялки. Состояние до запуска неправильной вернуть не могу. Много работали уже после этого. Неправильной удалялкой я почистил заказы за 1-1.5 месяца а после правильной косяки на весь год а не только от тех заказов которые неправильно удалены. По крайней мере в режиме загрузка задания видны на всех рабочих днях года. Присоединить их все нереально просто!
Вот посмотрел еще раз, больные задания в расписаниях загрузки только в феврале. До февраля есть задания без связей. Они просто удаляются. В феврале есть задания и задания на участок. Некоторые из них тоже без связей и их можно удалить. Удалять? Хуже не сделаю? Остальные февральские приклеить к заказу по вашей инструкции и попробовать почистить и удалить заказ, правильно?
shurick пишет: Я вернулся к состоянию базы до запуска исправленной удалялки
В этом смысла нет.
Раз нет возможности откатиться на самое начало, то тогда возьмите базу, после того, как почистили её уже новой утилитой. Дальше, что мешает сделать так, как я предлагал выше?
Уже вернулся. Это ж рабочая база. Я не знал сделал ли я хуже а в понедельник нужно было продолжать работу. Так можно просто удалить задания которые ни с чем не связаны?
Которые ни с чем не связаны то точно удалить можно. Хуже от этого не будет. Другое дело, что руками в справочнике они так просто "в лоб" могут и не удалиться. С "заданиями на участок" могут оказаться связаны "задания на производство". Внутри там всяческие "запланированные этапы" могут быть, связанные объекты, трудовые ресурсы, параметры. Руками будете всё это удалять?
Чем мой способ то плох?
Сейчас проверил на копии вашей базы. На которой тестировали удаление заданий. Там осталось "подвисших" заданий тысячи четыре примерно суммарно. Минут за 15 где-то всё удалил. Ничего не осталось.
Хорошо так и сделаю. Еще после удаления заказов на первом неправильном этапе в обеспеченности появились странные цифры. Скриншот расшифровки затребованного одной из позиции материала. Получается дефицит которого на самом деле нет.
Это уже из другой оперы. Это вы вручную "требования" создали когда-то для заказа. Потом заказ удалили. Но "требования" то остались. Надо их или удалить, или статус "не действует" им поставить, чтобы они не учитывались в расчётах.
Если хотите обсудить этот вопрос, то пожалуйста, вынесите его в отдельный топик. Он не соответствует заявленной в этом топике теме.
Как раз "заданий на участок" то, по идее, уже не должно уже быть. Лишних, по крайней мере. Вроде, их же и чистили. Если делали так, как я выше написал, то по идее у Вас должно остаться только некоторое количество "заданий на производство". Так?
нет. полно и тех и других в районе февраля где удалял неправильной удалялкой. дальше действительно только задания, задания на производство и составы смены.
Константин Чилингаров пишет: 1. Создать тестовый заказ с 1 позицией в нём 2. Открыть получившуюся карту заказа в режиме Компоненты. Встать на единственный компонент, открыть для него зависимое окно Задания. 3. Скопировать из справочника Задания все "потерянные" задания типа "Задание на участок", которые остались в справочнике. Вставить их в открытое в п.2 окно Задания для компонента карты заказов. Тип связи использовать "Задание на участок".
Тем самым мы приделываем все потерянные "задания на участок" к позиции своего тестового заказа.
После этого натравить на этот тестовый заказ утилиту "Удаление заданий".
1. Создаём тестовый заказ с одной позицией. Можно взять оставшийся от предыдущей части, если вы его ещё не удалили. 2. Открываем для этого заказа График производства. 3. Встаём на единственную позицию заказа, открываем График работ (по сменам) для неё. 4. С помощью "+" добавляем вручную одно задание (любую операцию).
Первая подготовительная часть закончена. Дальше доделываем вручную.
5. Идём в справочник Задания. Выделяем там все подвисшие "задания на производство". Нажимаем Копировать. 6. Идём в Коллекции компонентов. Открываем карту нашего тестового заказа в режиме Компоненты. 7. Встаём на единственный компонент, открываем зависимое окно Задания. 8. В открывшемся окне видим одну строчку - "Задание на участок". Встаём на неё и открываем для неё ещё одно зависимое окно Задания. Сюда вставляем все скопированные "задания на производство".
Итого должна получиться следующая структура: Карта заказа -> Изделие -> "Задание на участок" -> Все "задания на производство", которые нужно удалить
Всё. После этого выбираем карту своего тестового заказа и на неё напускаем утилиту удаления заданий.
После массового удаления чего-либо (например, заданий), нужно сделать следующее:
1. Очистить журнал событий (меню Администрирование - Сеансы, всё кроме незакрытых удалить). 2. Выполнить запрос [Health].[RefreshDependencies] 3. Выполнить "сжатие" (shrink) базы данных. 4. Выполнить запрос [Health].[UpdateStatistics]
Если пропустить п.1 или п.3., то размер базы не уменьшится. Скорее даже, наоборот, увеличится.
Ну и, естественно, перед этими всеми манипуляциями не лишним будет сделать резервную копию, если хотите чтобы история где-то осталась на всякий случай.