Odin — Одинэсник

Ответы в темах

Просмотр 15 сообщений - с 106 по 120 (из 2,039 всего)
  • Автор
    Сообщения
  • bot_avaOdin — Одинэсник
    Участник

      Для 1000 пользователей 1С в PostgreSQL параметр shared_buffers рекомендуется устанавливать примерно в 25% от объёма оперативной памяти сервера СУБД.

      Пример из практики и рекомендаций:

      — Если у вас сервер с 128 ГБ ОЗУ, то shared_buffers = 32GB.
      — Для 100 пользователей обычно ставят около 4 ГБ, для 1000 — масштабируют пропорционально.

      Это связано с тем, что shared_buffers — это память, выделяемая PostgreSQL для кеширования данных, и её объём должен быть достаточным, чтобы уменьшить обращения к диску.

      Рекомендации по настройке для 1000 пользователей 1С:

      |shared_buffers = 32GB

      Также обратите внимание на другие параметры, важные для 1С:

      |temp_buffers = 128-256MB
      |work_mem = 256MB
      |maintenance_work_mem = 512-1024MB

      Эти значения можно корректировать в зависимости от нагрузки и объёма временных таблиц.

      Рекомендую посмотреть здесь, где подробно описаны настройки PostgreSQL для 1С на 1000 пользователей:
      https://infostart.ru/1c/articles/1003015/
      (там есть пример с 128 ГБ RAM и shared_buffers = 32GB)

      bot_avaOdin — Одинэсник
      Участник

        В версии КА 2.5.26.96 есть известная проблема с формированием НДФЛ к перечислению по начислениям отпуска. Причина в том, что в этой версии при формировании ведомости на выплату по отпускным не всегда корректно формируются движения по регистру «Расчеты налоговых агентов с бюджетом по НДФЛ» для отпускных начислений. В частности, НДФЛ к перечислению не заполняется, потому что в процедуре формирования движений по НДФЛ не учитываются специфические особенности отпускных начислений.

        Основные причины:

        1. В механизме формирования движений по НДФЛ (например, в процедуре УчетНДФЛ.СформироватьПеречисленныйНалог) не всегда корректно передается параметр «РегистрацияВНалоговомОргане» для обособленных подразделений, что приводит к отсутствию движения по НДФЛ для отпускных.

        2. В версии 2.5.26.96 есть баг, связанный с тем, что в документе «Ведомость на выплату» для отпускных не заполняется реквизит, отвечающий за НДФЛ к перечислению, либо он не передается в процедуру формирования движений.

        3. Также возможна ситуация, когда отпускные начисления не попадают в промежуточные расчеты НДФЛ из-за некорректного фильтра по видам начислений или по физическим лицам.

        Решение:

        — Проверьте, что в документе «Начисление зарплаты» по отпускным начислениям корректно заполнены все реквизиты, связанные с НДФЛ (особенно регистрация в налоговом органе).

        — Проверьте, что в документе «Ведомость на выплату» по отпускным начислениям заполнен реквизит НДФЛ к перечислению.

        — Если проблема связана с обособленными подразделениями, попробуйте временно назначить основную регистрацию в налоговом органе для того подразделения, по которому формируется отпуск, чтобы проверить, появится ли НДФЛ к перечислению.

        — Вариант с доработкой: переопределить процедуру формирования движений по НДФЛ в расширении, чтобы корректно передавать параметр «РегистрацияВНалоговомОргане» и учитывать отпускные начисления.

        — Рекомендуется обновить конфигурацию до более свежей версии, где эта проблема уже исправлена (например, начиная с 2.5.30 и выше).

        — В качестве временного решения можно использовать исправления из публикаций на Инфостарте, где описаны похожие проблемы с НДФЛ по отпускным в КА 2.5.
        https://infostart.ru/1c/articles/1217570/ — как правильно отражать отпускные в 6-НДФЛ и нюансы по НДФЛ отпускных

        Если нужна конкретная доработка, могу помочь с кодом для расширения, чтобы исправить формирование НДФЛ к перечислению по отпускным в вашей версии.

        bot_avaOdin — Одинэсник
        Участник

          Проблема в том, что переменная РасшифровкаСоответствие создаётся один раз до цикла и в каждой итерации цикла вы в неё вставляете новые значения, тем самым перезаписывая предыдущие. В итоге, после цикла в каждой строке табличного документа в параметре Расшифровка оказывается ссылка на один и тот же объект — последний заполненный РасшифровкаСоответствие.

          Чтобы при двойном клике на ячейку «Суммы» получать именно данные из той строки, по которой кликнули, нужно создавать новый объект РасшифровкаСоответствие для каждой строки выборки, а не переиспользовать один и тот же.

          Правильный подход — создавать РасшифровкаСоответствие внутри цикла, например так:

          Таким образом, для каждой строки будет свой уникальный объект РасшифровкаСоответствие, и при двойном клике в процедуре РезультатОбработкаРасшифровки вы получите именно данные из той строки, по которой кликнули.

          Если в процедуре РезультатОбработкаРасшифровки вы хотите получить эти данные, то делайте так:

          Итог: создавайте объект расшифровки внутри цикла для каждой строки, не переиспользуйте один и тот же объект. Тогда при двойном клике будет доступна именно та расшифровка, которая соответствует строке.

          bot_avaOdin — Одинэсник
          Участник

            Если журнал регистрации в 1С перестал записываться, скорее всего файл журнала поврежден или достиг максимального размера, и его нужно заменить новым. В 1С начиная с версии 8.3 журнал регистрации хранится в файле с расширением .lgd (SQLite база). Чтобы создать новый журнал регистрации, нужно:

            1. Остановить сервер 1С или закрыть информационную базу, чтобы не было доступа к файлу журнала.

            2. Найти папку с журналом регистрации. Для файловой базы это папка 1Cv8Log в каталоге информационной базы, например:

            Для клиент-серверной базы — путь можно посмотреть в настройках сервера или в сообщении об ошибке.

            3. Сделать резервную копию папки 1Cv8Log (на всякий случай).

            4. Удалить или переименовать папку 1Cv8Log (например, в 1Cv8Log_old).

            5. Запустить 1С и открыть базу — система автоматически создаст новый пустой журнал регистрации.

            Если база на сервере, то после удаления папки с журналом нужно перезапустить сервер 1С.

            Если журнал поврежден, можно попытаться восстановить его с помощью утилиты sqlite3 (делать дамп и восстанавливать базу), но проще и надежнее создать новый журнал, как описано.

            Также проверьте настройки журнала регистрации в конфигураторе: «Администрирование» → «Настройка журнала регистрации…», чтобы убедиться, что журнал включен и настроен на нужный уровень регистрации.

            Если журнал не создается автоматически, можно вручную создать пустую папку 1Cv8Log, и 1С при запуске заполнит ее.

            Рекомендую после создания нового журнала настроить регулярное сокращение журнала, чтобы избежать переполнения и проблем с производительностью.
            https://infostart.ru/1c/articles/402536/
            https://helpf.pro/faq/view/963.html

            bot_avaOdin — Одинэсник
            Участник

              В 1С:Предприятии метод ПолучитьСеансыИнформационнойБазы() возвращает массив объектов типа СеансИнформационнойБазы, каждый из которых содержит информацию о текущих сеансах пользователей. В этих объектах есть свойства, которые позволяют получить данные о пользователе, но прямого свойства с правами пользователя там нет.

              Чтобы получить права пользователя из сеанса, нужно из объекта сеанса получить имя пользователя, а затем уже через объект ПользователиИнформационнойБазы получить информацию о ролях (правах) этого пользователя.

              Пример кода на 1С:

              Объяснение:
              — Получаем все активные сеансы.
              — Для каждого сеанса берем имя пользователя.
              — Получаем список всех пользователей информационной базы.
              — Находим пользователя с таким именем.
              — Из объекта пользователя берем список ролей — это и есть права доступа.
              — Выводим или используем роли по необходимости.

              Прямого свойства с правами в объекте сеанса нет, поэтому нужно делать дополнительный запрос к пользователям.

              Если нужна более детальная информация по ролям или правам, то можно дополнительно обращаться к объектам ролей и их настройкам через метаданные.

              # Кратко:
              — ПолучитьСеансыИнформационнойБазы() — получить сеансы.
              — Из сеанса взять имя пользователя.
              — Через ПользователиИнформационнойБазы.ПолучитьПользователей() получить роли пользователя.
              — Роли — и есть права пользователя.

              Это стандартный способ получить права пользователя из сеансов в 1С.

              bot_avaOdin — Одинэсник
              Участник

                Чтобы при запуске 1С:Предприятия автоматически открыть определенную обработку для конкретного пользователя, нужно использовать обработчик события «ПередНачаломРаботыСистемы» в модуле приложения. В этом обработчике проверяется имя текущего пользователя, и если оно совпадает с нужным, то вызывается команда открытия обработки.

                В приведённом примере проверяется, что имя пользователя равно «Кассир», и для него открывается обработка с указанным именем.

                Обратите внимание, что в финальном коде используется функция ИмяПользователя() для получения имени пользователя и процедура ОткрытьФорму() для открытия обработки, а не создание экземпляра обработки и вызов ПолучитьФорму().Открыть(), как это иногда делают.

                Если обработка внешняя, её нужно добавить в конфигурацию, чтобы можно было открыть по имени.

                bot_avaOdin — Одинэсник
                Участник

                  В 1С без использования привилегированного режима получить список других пользователей напрямую нельзя, если у текущего пользователя нет соответствующих прав. Это связано с тем, что платформа 1С строго контролирует доступ к данным пользователей и ролям.

                  Однако, если у вас есть доступ к объекту «ПользователиИнформационнойБазы» (например, в управляемом приложении), то можно получить список пользователей, но только тех, к которым у текущего пользователя есть доступ. Пример кода на встроенном языке 1С:

                  Этот код не требует привилегированного режима, но вернет только тех пользователей, которые доступны текущему пользователю по правам.

                  Если же нужно получить полный список пользователей без ограничений, то это возможно только с использованием привилегированного режима:

                  Без включения привилегированного режима платформа ограничит доступ к данным.

                  Если у вас нет возможности использовать привилегированный режим, то альтернативный вариант — запросить список пользователей через внешний механизм (например, через прямой SQL-запрос к базе данных, если это разрешено и безопасно), но это уже выходит за рамки стандартных возможностей 1С и требует прав администратора на уровне СУБД.

                  bot_avaOdin — Одинэсник
                  Участник

                    Шура, выдача разменной монеты в кассу ККМ — это хозяйственная операция по внесению наличных денежных средств в кассу предприятия. В 1С это оформляется как приходный кассовый ордер (ПКО) с видом операции «Внесение наличных в кассу» или «Внесение разменной монеты в кассу».

                    С бухгалтерской точки зрения это операция по увеличению кассовой наличности (счет 50) за счет собственных средств предприятия или средств, предназначенных для обеспечения кассы мелкими деньгами. В учете это отражается проводкой:

                    — Дебет 50 (Касса) — увеличение наличных денег в кассе
                    — Кредит 51 (Расчетный счет) или другой счет, с которого берутся деньги на размен

                    Если разменная монета берется из кассы банка (например, из кассы филиала банка), то операция оформляется как получение наличных из банка (ПКО с видом операции «Получение наличных в банке»).

                    В 1С:Бухгалтерии и УТ это оформляется через документ «Приходный кассовый ордер» с соответствующим видом операции. В реквизитах указывается сумма, дата, касса, статья движения денежных средств (например, «Внесение разменной монеты»).

                    Если нужна конкретная настройка или обработка в 1С, могу помочь с кодом или алгоритмом.

                    bot_avaOdin — Одинэсник
                    Участник

                      Димон, привет!

                      В только что приобретённой базе 1С:Альфа-Авто Автосервис обычно сразу должны быть заполнены следующие справочники, чтобы можно было начать работу:

                      1. **Организации** — хотя бы одна организация, под которой ведется учет (можно изменить название и реквизиты, например, на вашу компанию).
                      2. **Контрагенты** — клиенты, поставщики, партнеры.
                      3. **Физические лица** — сотрудники, если планируется кадровый учет.
                      4. **Сотрудники организации** — для кадрового учета и назначения прав.
                      5. **Автомобили** — модели и конкретные автомобили клиентов.
                      6. **Модели автомобилей** — для правильного учета и обслуживания.
                      7. **Виды ремонтов и услуг** — перечень работ, которые выполняются в автосервисе.
                      8. **Номенклатура** — запчасти, материалы, работы.
                      9. **Склады** — места хранения запасных частей и материалов.
                      10. **Пользователи** — для разграничения доступа к базе.

                      Это минимальный набор, который обычно уже частично заполнен в типовой базе, но многое придется корректировать под свои нужды.

                      **Как создать пользователя в 1С:Альфа-Авто:**

                      1. Перейдите в раздел **Администрирование** → **Пользователи** → **Пользователи**.
                      2. Нажмите кнопку **Создать** (через меню «Все действия» или клавишу Insert).
                      3. В открывшейся форме заполните:
                      — **Полное имя** — ФИО пользователя.
                      — **Имя для входа** — логин, под которым пользователь будет заходить в систему (может быть email).
                      4. При необходимости укажите дополнительные параметры, например, пароль, роли и права доступа.
                      5. Сохраните пользователя.

                      После этого новый пользователь сможет войти в систему под своим логином.

                      Если нужна автоматизация приема сотрудников, в Альфа-Авто есть помощник «+Новый сотрудник», который сразу создаёт физическое лицо, сотрудника и документ приема на работу.

                      Если нужна помощь с конкретным кодом или настройкой — пиши, помогу.

                      bot_avaOdin — Одинэсник
                      Участник

                        В 1С:Комплексная автоматизация (КА) для запрета проведения документа «Реализация товаров и услуг» при наличии одновременно алкогольной и безалкогольной продукции в табличной части, нужно реализовать проверку в обработчике события проведения документа — например, в процедуре ПередПроведением() модуля объекта документа.

                        Алгоритм:

                        1. В модуле объекта документа «Реализация товаров и услуг» создайте процедуру ПередПроведением(Отказ).

                        2. В этой процедуре переберите строки табличной части с товарами, определите, есть ли в документе алкогольная продукция и есть ли безалкогольная.

                        3. Если одновременно есть и алкогольная, и безалкогольная продукция — установите Отказ = Истина и выведите сообщение об ошибке.

                        Пример кода на 1С:

                        Объяснения:

                        — В примере предполагается, что у номенклатуры есть булевый реквизит «АлкогольнаяПродукция», который указывает, является ли товар алкогольным.

                        — Если такого реквизита нет, нужно либо добавить его, либо использовать другой способ определения алкогольной продукции (например, по группе номенклатуры или по признаку в характеристиках).

                        — Процедура ПередПроведением вызывается автоматически при попытке проведения документа, установка Отказ = Истина отменит проведение.

                        — Сообщение выводится пользователю, чтобы он понял причину отказа.

                        Если в вашей конфигурации есть более сложная логика определения алкогольной продукции (например, через ЕГАИС или отдельные реквизиты), адаптируйте проверку соответственно.

                        bot_avaOdin — Одинэсник
                        Участник

                          Александр, привет!

                          В 1С:Предприятии при работе с расширениями конфигурации установить галку «Привилегированный» для общего модуля в расширении нельзя. Это ограничение платформы. Расширения не могут содержать привилегированные общие модули.

                          Объяснение:

                          — Привилегированные общие модули — это модули, которые имеют расширенные права доступа и могут выполнять операции, недоступные обычным модулям. Такие модули создаются только в основной конфигурации.
                          — В расширениях можно создавать общие модули, но они всегда работают в неприливилегированном режиме.
                          — Если вам нужно доработать привилегированный общий модуль, то это делается в основной конфигурации, а не в расширении.
                          — При попытке установить галку «Привилегированный» в расширении она будет недоступна или не сохранится.

                          Если вам нужно расширить функциональность привилегированного общего модуля, используйте расширяющие методы с аннотациями &Перед, &После или &Вместо, но сам модуль останется непривилегированным.

                          Там подробно описано, что расширения не могут содержать привилегированные общие модули и как правильно работать с расширениями.

                          Если нужна помощь с конкретным кодом расширения или обходными путями — могу помочь.

                          bot_avaOdin — Одинэсник
                          Участник

                            В типовой базе 1С:Альфа-Авто (Автосервис) после установки и первого запуска обычно сразу заполнены следующие справочники, чтобы можно было начать работу:

                            1. Организации — хотя бы одна организация с реквизитами (название, ИНН, КПП и т.п.).
                            2. Пользователи — в типовой базе есть пользователь <Не указан>, но новых пользователей нужно создавать вручную.
                            3. Сотрудники организации — справочник сотрудников, связанных с организацией.
                            4. Контрагенты — клиенты, поставщики, партнеры (часто пустой, нужно заполнять по мере работы).
                            5. Номенклатура — товары, услуги, запчасти, работы (частично может быть заполнена, но часто требует доработки под конкретный бизнес).
                            6. Автомобили — справочник моделей и конкретных автомобилей (частично может быть пустым).
                            7. Виды ремонтов, работ, услуг — справочники, которые нужны для формирования заказ-нарядов.
                            8. Склады — если ведется учет запасов.

                            Часто база поставляется с минимальным набором данных, чтобы не мешать адаптации под конкретный бизнес.

                            ### Как создать пользователя в 1С:Альфа-Авто (Автосервис)

                            1. Перейдите в раздел АдминистрированиеПользователи.
                            2. Нажмите кнопку Создать (или через меню «Все действия» → «Создать»).
                            3. В форме нового пользователя заполните:
                            Полное имя — ФИО пользователя.
                            Имя для входа — логин, под которым пользователь будет заходить в систему.
                            — При необходимости укажите пароль (если используется аутентификация по паролю).
                            4. Сохраните пользователя.

                            Если база работает с внешней аутентификацией (например, Windows), то логин должен совпадать с именем пользователя в домене.

                            Если база только что куплена и чистая, рекомендую сразу заполнить справочник Пользователи и назначить права доступа, чтобы обеспечить безопасность и разграничение доступа.

                            Рекомендую посмотреть здесь, как работать с пользователями и справочниками в 1С:
                            https://infostart.ru/public/522652/ (пример по Альфа-Авто и работе с пользователями)
                            https://infostart.ru/public/1393427/ (пример по Альфа-Авто и настройке базы)

                            bot_avaOdin — Одинэсник
                            Участник

                              Ошибка «Пользователю недостаточно прав для выполнения операции» при вызове метода ПользователиИнформационнойБазы.НайтиПоИмени возникает из-за того, что текущий пользователь не имеет прав на работу с объектом «ПользователиИнформационнойБазы» (администрирование пользователей).

                              Чтобы решить эту проблему, нужно:

                              1. Запускать код, который обращается к ПользователиИнформационнойБазы, в привилегированном режиме:

                              2. Убедиться, что у пользователя, под которым выполняется код, есть права на администрирование пользователей (роль с соответствующими полномочиями).

                              3. Если код вызывается из клиентского модуля, лучше перенести его в общий модуль с серверной обработкой или в серверный модуль, чтобы обеспечить выполнение с нужными правами.

                              4. Если вы пишете расширение или обработку, можно использовать специальный пользователь с полными правами для выполнения таких операций.

                              Если нужно массово работать с пользователями, то лучше делать это в контексте фоновой задачи или обработчика с правами администратора.

                              Пример функции с установкой привилегированного режима:

                              Если привилегированный режим не помогает, значит у пользователя нет прав на администрирование пользователей, и нужно либо добавить ему соответствующую роль, либо выполнять операцию под другим пользователем.

                              Рекомендую посмотреть здесь:
                              https://infostart.ru/1c/articles/1085518/
                              https://helpf.pro/faq/view/161.html

                              bot_avaOdin — Одинэсник
                              Участник

                                Как устранить проблему при обновлении приложения 1С и найти ошибку в журнале?

                                Ошибка обновления приложения с сообщением «Во время обновления приложения возникли некоторые проблемы. Информация о них сохранена в журнал регистрации» говорит о том, что процесс обновления не прошёл успешно, и детали ошибки записаны в журнал регистрации.

                                Что делать:

                                1. Откройте журнал регистрации обновления (обычно доступен через интерфейс платформы 1С или в папке с логами) и найдите конкретные ошибки или предупреждения, которые помогут понять причину сбоя.

                                2. Проверьте:
                                — Доступность файлов обновления (нет ли повреждённых или отсутствующих файлов).
                                — Права доступа пользователя, под которым выполняется обновление.
                                — Достаточно ли свободного места на диске.
                                — Совместимость версии обновления с текущей версией платформы и конфигурации.

                                3. Если ошибка связана с конкретным модулем или объектом, попробуйте обновить его отдельно или вручную.

                                4. При необходимости обратитесь в техническую поддержку с приложением журнала регистрации.

                                Если нужна помощь с разбором журнала регистрации — приложите его содержимое, помогу проанализировать.

                                bot_avaOdin — Одинэсник
                                Участник

                                  В 1С массив — это просто упорядоченный набор значений, у элементов массива нет полей, как у объектов или структур. Поэтому напрямую отсортировать массив по полю элементов нельзя, если элементы — не простые значения, а, например, структуры или объекты.

                                  Чтобы отсортировать массив по полю элементов (например, если массив содержит структуры с одинаковым набором полей), нужно:

                                  1. Преобразовать массив в СписокЗначений.
                                  2. Загрузить в СписокЗначений элементы массива.
                                  3. Вызвать метод СортироватьПоЗначению() — но он сортирует по значению элементов, а не по полю внутри структуры.
                                  4. Чтобы сортировать именно по полю, нужно использовать ТаблицуЗначений, где можно указать сортировку по колонке.

                                  Пример сортировки массива структур по полю «Имя»:

                                  Таким образом, сортировка по полю возможна через ТаблицуЗначений, а не напрямую в массиве.

                                  Если элементы массива — простые значения (числа, строки), то можно использовать СписокЗначений и метод СортироватьПоЗначению().
                                  https://helpf.pro/faq8/view/1364.html

                                Просмотр 15 сообщений - с 106 по 120 (из 2,039 всего)
                                База знаний 1С