Всем привет!
Проблема состоит в следующем.
К примеру есть Справочник Контрагенты.
В этом справочнике есть группа "удаленные", там хранятся помеченные на удаления элементы. Их достаточно много. После того как запускаешь процедуру "Удаление помеченных объектов", элементы находящиеся в группе "Удаленные" остаются не тронутыми. Т.е. процедура не удаляется объекты непосредственно. Скорее всего есть связь с какими-то используемыми объектами. Рассматривать каждый помеченный на удаление элемент индивидуально не вариант, так как их оч. много. Что можете посоветовать в данной ситуации?
Проблема состоит в следующем.
К примеру есть Справочник Контрагенты.
В этом справочнике есть группа "удаленные", там хранятся помеченные на удаления элементы. Их достаточно много. После того как запускаешь процедуру "Удаление помеченных объектов", элементы находящиеся в группе "Удаленные" остаются не тронутыми. Т.е. процедура не удаляется объекты непосредственно. Скорее всего есть связь с какими-то используемыми объектами. Рассматривать каждый помеченный на удаление элемент индивидуально не вариант, так как их оч. много. Что можете посоветовать в данной ситуации?
По теме из базы знаний
- Загрузка данных из ТСД с возможностью создания (определения) товаров с неизвестным штрихкодом + очистка справочника после загрузки.
- Очистка справочников
- Удаление неиспользуемых элементов справочников
- Очистка справочников
- Поиск и удаление неиспользованных элементов справочника для 1С: Бухгалтерии 3.0
Ответы
Подписаться на ответы
Инфостарт бот
Сортировка:
Древо развёрнутое
Свернуть все
(15) DenisCh,
да ничего, все СУБД хранят, и не брезгуют.
Не надо истерик :)
"Царь хороший - бояре плохие!" Ввернули такие ссылки для угнетения программистов, что дым коромыслом.
(18) fggf,
т.е. вы совершенно не представляете, что вы получите после замены ВСЕХ удаленных контриков на ОДНОГО "избранного", и какие остатки и движения будут у вас в базе? Тогда вы со своим "заказчиком" друг друга стоите :)
Всё хранить в текстовом виде в одной таблице!
да ничего, все СУБД хранят, и не брезгуют.
Не надо истерик :)
Перекрёстные ссылки придумали явные враги 1сников!
"Царь хороший - бояре плохие!" Ввернули такие ссылки для угнетения программистов, что дым коромыслом.
(18) fggf,
Понравился вариант, надо подумать.
т.е. вы совершенно не представляете, что вы получите после замены ВСЕХ удаленных контриков на ОДНОГО "избранного", и какие остатки и движения будут у вас в базе? Тогда вы со своим "заказчиком" друг друга стоите :)
(19) frc,
Бывают ситуации, когда данные в БД 1С попали из СУБДктоегознаеткак и среди справочниках есть такие элемементы о которых ни один ныне работающий на предприятии понятия не имеет... о_О
т.е. вы совершенно не представляете, что вы получите после замены ВСЕХ удаленных контриков на ОДНОГО "избранного"
Иногда это вполне разумный выход.
Бывают ситуации, когда данные в БД 1С попали из СУБДктоегознаеткак и среди справочниках есть такие элемементы о которых ни один ныне работающий на предприятии понятия не имеет... о_О
(21) olegka.ru,
эьл единстивенный случай - когда инфо в таком виде попала прии переносе из разных баз. Вот тогда можно заменять на "одного" (двух, трех..) контрагентов.
Во всех остальных случаях - получите не учетную базу, а набор записей для тестирования следующего кандидата на должность программиста :)
Бывают ситуации, когда данные в БД 1С попали из СУБДктоегознаеткак
эьл единстивенный случай - когда инфо в таком виде попала прии переносе из разных баз. Вот тогда можно заменять на "одного" (двух, трех..) контрагентов.
Во всех остальных случаях - получите не учетную базу, а набор записей для тестирования следующего кандидата на должность программиста :)
(19) frc,
PS
Кстати, бывают и вполне банальные ситуации, когда нужно именно вместо 1000 разовых контриков получить 1 избранного, и это связано уже не с программерами, а с "одарёнными" операторами или руководителями. Пример: оптовое предриятие торгует и в розницу; был контр. "Частное лицо", а затем появились "Ивановы, Петровы, Сидоровы", т.е. мусорные данные в БД.
т.е. вы совершенно не представляете, что вы получите после замены ВСЕХ удаленных контриков на ОДНОГО "избранного"
PS
Кстати, бывают и вполне банальные ситуации, когда нужно именно вместо 1000 разовых контриков получить 1 избранного, и это связано уже не с программерами, а с "одарёнными" операторами или руководителями. Пример: оптовое предриятие торгует и в розницу; был контр. "Частное лицо", а затем появились "Ивановы, Петровы, Сидоровы", т.е. мусорные данные в БД.
(1) fggf,
советую Вам не спешить и уточнить у заказчика почему эти контрагенты помечены на удаление?
С ними перестали работать?
Если да - зачем их удалять? Если мешают - повесить отбор на форму списка и подбора.
PS1 Они же есть не просят ? (я имею ввиду помеченных контрагентов:))
PS2 Клиент не всегда прав (из личного опыта)
советую Вам не спешить и уточнить у заказчика почему эти контрагенты помечены на удаление?
С ними перестали работать?
Если да - зачем их удалять? Если мешают - повесить отбор на форму списка и подбора.
PS1 Они же есть не просят ? (я имею ввиду помеченных контрагентов:))
PS2 Клиент не всегда прав (из личного опыта)
Можно сделать цикличное удаление, всех ссылок на помеченный удаление, но таким образом может вся база улететь, поэтому лично я ничего не могу предложить, кроме работы бухгалтера.
Ну или можно удалить физически тогда будут битые ссылки везде, так что не советую.
Ну или можно удалить физически тогда будут битые ссылки везде, так что не советую.
Если не удаленные документы ссылаются на удаленные элементы справочника, то их нельзя удалять, и это правильно. Скажем Контрагента пометили на удаление, а то что есть движения в прошлом году по нему забыли. Если все же необходимо провести зачистку базы, то нужно сделать "обрезание базы", в этом случае после удаления уже не нужных документов прошлых периодов удаляться и ставшие ненужными элементы справочника.
Попробуй воспользоваться обработкой Поиск и замена значений. После того как заменишь помеченный на удаление объект нужным объектом (ликвидируются ссылки на объект), запускаешь обработку Удаление помеченных объектов. Все эти обработки являются стандартными, их можно найти в Нете
Есть такой вариант решения:
1. С помощью обработки "поиск и замена значений" заменить всех контрагентов и их договора тоже (Обязательно!!!) на одного контрагента, например "СтарыйКонтрагент"
2. Удалить помеченые.
на выходе получим всего 1 помеченного контрагента, с безумным кол-вом связанных объектов :)
1. С помощью обработки "поиск и замена значений" заменить всех контрагентов и их договора тоже (Обязательно!!!) на одного контрагента, например "СтарыйКонтрагент"
2. Удалить помеченые.
на выходе получим всего 1 помеченного контрагента, с безумным кол-вом связанных объектов :)
(10) olegka.ru,
Понравился вариант, надо подумать.
База скульная, контрагенты - это один из справочников, т.е. есть их других.
общее колво контрагентов в базе под 100тыс. представьте себе сколько может быть помеченных на удаление.
автору тз по кайфу такие задачки подбрасывать.
Понравился вариант, надо подумать.
База скульная, контрагенты - это один из справочников, т.е. есть их других.
общее колво контрагентов в базе под 100тыс. представьте себе сколько может быть помеченных на удаление.
автору тз по кайфу такие задачки подбрасывать.
Если файловая база, то удаляем непосредственно, затем chDBL.exe и смотрим на битые ссылки и уже принимаем решение как восстанавливать. Жёсткий способ, но это на тот случай, если клиент требует типа сделайте все, что угодно только уберите помеченных на удаление.
Свертка и перенос остатков наверняка удалит не всех контрагентов, помеченных на удаление, помимо остатков по бух. счетам есть куча регистров, где тоже есть ссылки на этих самых контров. Но тут, конечно, многое зависит от мастерства того, кто будет делать свертку. А после свертки опять появятся новые удаленные контрагенты. Опять свертку делать будете? На мой взгляд, принимать решение о свертке нужно не на основе желания удалить ненужных контрагентов.
Есть такой вариант решения:
1. С помощью обработки "поиск и замена значений" заменить всех контрагентов и их договора тоже (Обязательно!!!) на одного контрагента, например "СтарыйКонтрагент"
2. Удалить помеченые.
на выходе получим всего 1 помеченного контрагента, с безумным кол-вом связанных объектов :)
1. С помощью обработки "поиск и замена значений" заменить всех контрагентов и их договора тоже (Обязательно!!!) на одного контрагента, например "СтарыйКонтрагент"
2. Удалить помеченые.
на выходе получим всего 1 помеченного контрагента, с безумным кол-вом связанных объектов :)
Обычно делаю также...
Поиск и замена - это конечно замечательно, только часто бывает после такой чистки по регистрам верификации или регистрации изменений, получаем объект не найден, а если еще настроенк какой нибудь обмен или РИБ, то вообще дрова.
Лучше конечно переносить остатки и резать базу. И чем мешают допустим 2-3 тысячи лишних контрагентов, на быстродействие не сказывается, на размер базы тоже не сильно, а вот документы старых периодов - это да, это объемы.
Какая выгода в том чтобы подчистить справочник контрагентов, таким зверским методом? (после замены ни один отчет не покажет ничего правильного, все сольется на одного контрагента)
Лучше конечно переносить остатки и резать базу. И чем мешают допустим 2-3 тысячи лишних контрагентов, на быстродействие не сказывается, на размер базы тоже не сильно, а вот документы старых периодов - это да, это объемы.
Какая выгода в том чтобы подчистить справочник контрагентов, таким зверским методом? (после замены ни один отчет не покажет ничего правильного, все сольется на одного контрагента)
Не всегда хотелки клиентов надо выполнять, бывают просят звезду с неба. Нужно проанализировать цели данной просьбы и насколько цель оправдывает средства. Может аргументация не стоит потраченных усилий. А вообще как по мне 2 варианта свернуть базу, и тогда возможно частично удаляться контрагенты, если по ним конечно остатков не будет висеть. Другой вариант - это заменить на одного, что, как по мне, тоже вариант кривоватый. Самый конечно оптимальный сесть бухгалтеру и самому анализировать каждую ссылку и документ, глядишь и ошибки найдутся. Я не удивлюсь если они пометили там и нужных контрагентов
Для получения уведомлений об ответах подключите телеграм бот:
Инфостарт бот