Исправлять ошибки в базе данных можно либо удаляя сбойную запись, либо так исправляя поля сбойной записи, чтобы она больше не была таковой. Выполнять эти действия нужно с пониманием характера неисправности и последствий предпринимаемых действий.
Ошибки в структуре файлов
(нарушения физической целостности)
Почти всегда после сообщений подобного рода следует огромный список нарушений логической целостности базы данных, поэтому лучше восстановить резервную копию базы данных.
Ошибки в данных (нарушения логической целостности)
Поскольку в словаре данных хранится не только информация о структуре таблиц базы данных, но и о связях между таблицами, есть возможность проверить корректность базы данных. При нормальной работе программы нарушений связей между таблицами не происходит. Но в результате сбоя системы, нарушений в физической целостности базы данных могут возникнуть какие-то ошибки в записях. Все эти нарушения отлавливаются при проверке базы данных программой Jinnee.
Ошибка «Не найдена запись»
Ошибка возникает, если в поле, которое должно ссылаться на другую запись, содержится ссылка, указывающая «в никуда».
Рис. 6-19 – Фрагмент ошибки «Не найдена запись»
То есть в поле записан определенный адрес записи, а в связанной таблице такой записи нет.
Рис. 6-20 – Переход к связанной записи
В нашем примере это выглядит так: запись с адресом 00000001 из таблицы «Разовые н/у» ссылается на связанную запись из таблицы «Расчёты» с адресом 00000732. Если перейти по связи в «Расчёты«, то будет выдано сообщение об отсутствии данной записи в таблице.
Рис. 6-21 – Предупреждение об ошибке
Ошибка «Связь не один в один»
Эта ошибка возникает в связях типа «один к одному» или «условная связь».
Рис. 6-22 – Фрагмент ошибки «Связь не один в один»
Эти связи организованы так, что обе связанные записи ссылаются друг на друга. Если же запись A ссылается на запись B, а та в свою очередь ссылается не на А, как должна бы, а на C, то будет выдано сообщение «связь не один в один». Для устранения таких ошибок нужно разобраться, кто же на кого, в конце концов, должен указывать.
Рис. 6-23 – Просмотр ошибочных записей
Например, таблицы «Сотрудники» и «Сотрудники(расширение)» связаны между собой отношением «один к одному». В нашем примере эта связь нарушена: запись 00000000 из таблицы «Сотрудники» ссылается на запись 00000001 из таблицы «Сотрудники(расширение)«. На эту же запись ссылается и запись 00000002 из таблицы «Сотрудники«.
Рис. 6-24 – Переход к связанной записи
В свою очередь, запись 00000001 из таблицы «Сотрудники(расширение)» ссылается не на запись 00000000, а на запись 00000002 из таблицы «Сотрудники«. Для исправления ситуации, необходимо либо удалить ошибочную запись 00000000, либо в поле связи указать значение «нет«.
Это простейший и самый распространенный случай. Теоретически могут быть и более сложные вариации.
Начиная с версии 2.2, добавлена возможность объединения «двойников» таблицы «Лица». У всех, кроме одной, дублирующихся записей по полю «Лицо_» требуется проставить значение «Нет», далее эти записи отбираются пробелом и объединяются с записью, в которой значение поля «Лицо_» было оставлено.
Ошибка «Ссылается не на узел»
Ошибка может возникнуть в иерархии, если какая-то запись ссылается не на узел, а на лист иерархии.
Рис. 6-25 – Фрагмент ошибки «Ссылается не на узел»
Запись 00000008 ссылается на запись 00000005, которая, в свою очередь, является листом и лежит в корне таблицы. По определению на лист иерархии не должна ссылаться никакая запись.
Рис. 6-26 – Вариант исправления ошибки
После такой операции все исправленные записи окажутся в корне соответствующего справочника СБиС++, и их можно будет переместить в нужное место стандартными операциями. Такое может не пройти для складской картотеки и для реестра документов, так как в корне этих таблиц могут находиться только специальные записи. Это уже специфика комплекса СБиС++. В этом случае нужно найти запись-узел и вместо ссылки на корень ввести ссылку на этот узел.
Ошибка «Неверный номер условной таблицы»
Ошибка, появляющаяся только в условной связи в записях общей таблицы.
Рис. 6-27 – Фрагмент ошибки «Неверный номер условной таблицы»
Напомним, что с одной стороны условной связи находится одна таблица, записи которой могут ссылаться на разные таблицы. В поле записи общей таблицы хранится название таблицы (определяемое по коду в словаре данных), на которую ссылается эта запись. Как видно из примера, запись 00000000 из таблицы «Лица» ссылается на таблицу «Номенклатура». При сбое в программе может случиться так, что в этом поле будет указан код несуществующей таблицы. В нашем примере, запись 00000002 ссылается на несуществующую таблицу с кодом «А».
Исправить ошибочную ситуацию можно следующими способами:
• наилучшим вариантом будет восстановить резервную копию БД;
Ошибка «Неверные данные в поле»
Эта ошибка может возникнуть в поле любого типа, не только в поле связи. Означает она, что значение в этом поле не удовлетворяет внутренним ограничениям поля. Например, для полей типа «целое» проверяется, входит ли число в определенный диапазон (задается разработчиком приложения).
Чтобы исправить эту ошибку, нужно ввести корректное значение в ошибочное поле. Если же большинство полей записи содержат явно ошибочные данные, лучше просто удалить эту запись.
Ошибка «Неверные данные в большом двоичном поле»
Эта ошибка может возникать при аварийном отключении питания, разрушении файловой системы или сбое в работе аппаратной части. В результате подобных событий в таблицах базы данных могут быть потеряны значительные объемы данных.
Для устранения таких ошибок необходимо выполнить оптимизацию тех таблиц, данные в которых были разрушены.
Заключение
Поскольку удаление или изменение с помощью «Jinnee» записи базы данных может привести к нарушениям логической целостности, следует, «разобравшись» со всеми ошибочными записями, повторить проверку до полного отсутствия ошибок в базе данных.
Если была выявлена ошибка, описание которой не рассматривалось в данном руководстве, то за подробным разъяснением дальнейших действий по устранению этой проблемы, можно обратиться к специалистам по телефонам «Горячей линии СБиС++».
В ActionScript, равно как и в таких языках, как Pascal или JavaScript, объявить переменную можно, используя ключевое слово var:
var new_obj; // Создана новая переменная.
Присваивая переменной имя, нужно соблюдать правила задания идентификаторов. Особенно важно помнить, что в ActionScript появилась полная чувствительность к регистру, а также, что имя не может начинаться с цифры и совпадать с лексемами из словаря языка. Переменной при создании автоматически присваивается значение undefined:
trace(new_obj); // Выводит: undefined
Впрочем, переменные редко объявляются пустыми. Обычно им сразу же ставится в соответствие некоторое конкретное значение (на худой конец — null). Делается это при помощи оператора присваивания «-», который мы использовали уже десятки раз:
var new_obj=null; // Если переменная изначально не имеет значения,
// то ей нужно присвоить null
Одновременно можно объявить и несколько переменных, для чего нужно использовать оператор «,»:
var а=1, b=2, с=3; // Строка эквивалентна var a=1; var b=2; var c=3;
Если переменная будет хранить объекты данных только одного типа, ее стоит типизировать.
Во Flash 4, до появления современного ActionScript, для объявления и переопределения переменных использовалось предложение set(name, expression), где name — Имя, expression — присваиваемое выражение. Например:
set(a, null); // Эквивалентно a=null;
В настоящее время функции предложения set() сузились до создания переменных с динамическими именами:
var i:Number = Math. round(Math. random()»10); // Генерируем случайное
// число от 0 до 10
set(«var»+i,»новая переменная»); // Создаем переменную со случайным именем
trace(eval(«var» + i)); // Выводит: «новая переменная»
Надо признать, что в современных версиях Flash предложение set() используется достаточно редко, что связано с тем, что у него имеется куда более мощный конкурент — массивы (а точнее, оператор доступа к свойствам «()», который часто называют оператором доступа к элементам массива — отчасти из-за схожести с литералом массива «[]»). Однако если массивы не применяются, то set() просто незаменима (и таковой она была во Flash 4), так как невозможно присвоить значение переменной, переведя строку в идентификатор при помощи eval():
eval(«variable»)=3; // Эта строка вызывает ошибку
set(«variable»,3); // Верное выражение
Чтобы создать переменную с динамически формируемым именем более технично, чем с использованием предложения set, нужно применить следующую запись:
где this — указатель на текущую временную диаграмму (ее свойствами являются все переменные размещенного на ней кода); «name» — имя переменной; value — объект данных, который должна хранить переменная.
this [«variable»] = «Привет»;
trace(variable); // Выводит: Привет
Переменные, которые создаются при помощи предложения set или оператора «[]», не могут быть типизированы. Впрочем, при этом правильнее говорить о создании свойства временной диаграммы, содержащей код, чем о переменной.
Хорошим тоном в ActionScript-программировании является объявление всех переменных сценария в одном месте — в выделенной комментариями области вверху листа с кодом. Такой подход помогает избежать повторения идентификаторов в больших программах, а также делает сценарий более читабельным и понятным для сторонних лиц. Весьма оправданно объявлять вместе с основными переменными и переменные служебные — для хранения промежуточных результатов или флагов состояния.
//*******Переменные*********************************
var speed:Number=10; // Скорость объекта
var size:Number=100; // Размер объекта в пикселях
var crash:Number=null; // Расстояние по дубликата
//**************************************************
Имеется и более существенная причина, по которой все переменные должны объявляться в начале сценария.
Чтобы понять ее, проанализируйте следующий код:
function func():Void
func (); // Выводит: undefined Привет.
var per:String = «Пока»;
function func2():Void
Дело в том, что вызов функции может предшествовать ее определению. А вот прочитать значение переменной выше строки ее задания невозможно. Такая двойственность очень часто приводит к путанице и ошибкам. Например, если вы из функции А() вызываете функцию В(), которая использует переменную per, объявленную между ними, то активация А() выше определения per приведет к неопределенности:
function A():Void
А(); // Выводит: undefined
var par:String = «Привет»;
А(); // Выводит: Привет (вызов расположен ниже определения переменной)
function B():Void
ActionScript не является строгим языком в отношении объявления переменных. Так, если вы попытаетесь присвоить некоторое значение несуществующей переменной, то интерпретатор, проверив соответствующую цепочку областей видимости, просто автоматически создаст ее:
my_var = null; // Результат выполнения такой записи в большинстве
// случаев аналогичен var my_var=null;
Автоматическое создание переменных не является общепринятой нормой: в большинстве универсальных языков программирования появление неизвестного идентификатора вызывает ошибку. В ActionScript же использование var не обязательно, J но является рекомендованным. И на то имеются веские причины:
• Явное определение переменных позволяет сделать сценарий более четким, облегчая тем самымего отладку и переделку.
• Создавая переменную с использованием var, вы гарантируете, что при этом не произойдет простого переопределения одноименной ей переменной, принадлежащей к вышележащей области видимости (это важно в случае локальных переменных функций).
Ключевое слово var позволяет строго типизировать переменные. Если попытаться задать тип переменной без var, то произойдет сбой при компиляции.
Желаем успешной сдачи отчетности!
Типичные проблемы, возникающие при отправке отчетности с помощью сервиса «СБИС Электронная отчетность»
Проблема:
При отправке отчета/письма в госорган появляется сообщение «Направление сдачи не зарегистрировано. Повторите отправку позже».
Причина:
По требованиям госорганов Ваша электронная подпись должна быть зарегистрирована на сервере инспекции. Этот процесс запускается автоматически и занимает от нескольких минут до нескольких часов в пиковые периоды сдачи отчетности.
Как исправить:
Повторите отправку отчетов позже.
Если время регистрации затягивается, то обратитесь в службу технической поддержки Вашего специализированного оператора связи.
Проблема:
Во время отправки возникли ошибки при форматно-логической проверке.
В реестре отчетности или в календаре налогоплательщика Вы увидите отчет со статусом « ». Данный статус означает, что Ваш отчет не был отправлен.
Причина:
В отчете обнаружена ошибка.
Как исправить:
Система СБИС сама подскажет, где именно допущена ошибка. Зайдите в неотправленный отчет. Список ошибок откроется после нажатия кнопки «Отправить».
Прочитайте описание ошибки, внесите необходимые исправления и повторите отправку отчета.
При отправке отчета «Налоговая декларация по налогу на прибыль организаций» у Вас выявлена ошибка «Отсутствует обязательное поле «Дата формирования документа». Это означает, что в форме не указана дата составления отчета.
Если ошибок больше не обнаружено, то отчет уйдет в госорган на проверку. Повторите те же действия и с другими отчетами, в которых обнаружены ошибки.
Проблема:
У выбранного госоргана стоит красный восклицательный знак.
Причина:
В случае госоргана данное условное обозначение говорит о том, что сертификат ключа Вашей ЭП еще не зарегистрирован в указанной инспекции.
Как исправить:
Обычно регистрация занимает от нескольких минут до нескольких часов в пиковые периоды сдачи отчетности. Просто необходимо немного подождать.
Если регистрация не завершается больше суток, то обратитесь в службу технической поддержки Вашего оператора электронного документооборота и уточните, на какой стадии находится процесс регистрации.
Наиболее распространенные вопросы при сдаче отчетности в контролирующие органы
Вопрос:
Как найти нужную отчетную форму в СБИС?
Ответ:
Чтобы быстро найти нужный отчет:
в поле «Поиск» начните вводить название формы или её код (КНД, ОКУД).
Вопрос:
Как добавить направление сдачи отчетности? (Если у Вашей компании сменилась налоговая инспекция, отделение пенсионного фонда или орган службы статистики)
Ответ:
Для того чтобы сдавать отчетность в новый госорган, его, прежде всего, нужно указать его в СБИС.
В разделе «Отчетность» перейдите на вкладку «Куда сдавать», у нужного направления сдачи нажмите «добавить» и выберите госорган из справочника.
Чтобы удалить ненужный госорган, наведите курсор на него и нажмите .
Если у организации есть электронная подпись для отправки отчетности, автоматически в госорган будет отправлена информация о регистрации нового абонента.
Если количество госорганов, в которые вы сдаете отчетность, превышает количество, предусмотренное Вашим тарифным планом, обратитесь к менеджеру для расширения лицензии.
Вопрос:
Как поменять отправителя в отчете?
Ответ:
В Вашей системе СБИС может быть несколько налогоплательщиков, по которым ведется документооборот. Их можно увидеть в нижней части окна главной страницы в разделе «Наши организации и ИП».
Выбрать организацию, по которой Вы будете формировать отчет или просматривать информацию, можно:
Вопрос:
Как проверить подготовленный отчет перед отправкой с помощью СБИС?
Ответ:
Чтобы выполнить проверку в отчете нажмите «Проверить отчет»
В результате проверки будет сформирован протокол. В нем перечислены строки, в которых были обнаружены нарушения контрольных соотношений. Нажав на ссылку, Вы сможете быстро перейти к любой строке с ошибкой и внести необходимые изменения.
Протокол проверки можно распечатать или сохранить в файл. После внесения изменений повторите проверку и при отсутствии ошибок отправьте его в госорган.
Вопрос:
Как узнать, что отчет сдан?
Ответ:
Обработка отчетности в инспекции обычно занимает какое-то время, не превышающее впрочем установленный российским законодательством срок.
Периодически проверяйте в календаре или реестре отчетности, какой статус у отправленного Вами отчета.
Статус означает, что отчет успешно сдан.
Ознакомиться со списком документов, полученных в ответ на Вашу отчетность, и с их содержанием Вы можете прямо в отчете. Для этого откройте его, на стикере кликните иконку , а для просмотра содержания документа об ошибке нажмите на его название.
Вопрос:
Как просмотреть ответы от контролирующих органов в СБИС?
Ответ:
Отчет не считается сданным до тех пор, пока оператор электронного документооборота и госорган не прислали Вам все необходимые документы, подтверждающие, что отчет принят в инспекции.
В окне доставки почты отображается вся необходимая информация по отправляемым и получаемым документам.
Просмотреть результат получения ответов (входящие письма, уведомление о получении Вашего отчета спец. оператором, извещение о вводе и пр.) можно непосредственно из окна доставки, просто кликнув левой кнопкой мыши по интересующему Вас документу.
Если Вами получен положительный протокол проверки, то отчет сдан.
Также Вы можете распечатать полученные документы, но юридической силы они иметь не будут.
Вопрос:
Что делать, если отчет не сдан?
Ответ:
Отрицательный статус означает, что Ваш отчет не принят инспекцией.
Чтобы ознакомиться с причиной отказа, на стикере в отчете нажмите иконку и кликните по ссылке с уведомлением об отказе (или уточнении).
Консультации по электронной отчетности СБиС
К Вашим услугам новая линия консультаций для пользователей программы электронной отчетности СБиС++. Мы готовы Вам помочь в вопросах составления и отправки электронной отчетности, а также работе программы в целом.
Электронная отчетность СБИС++
Установка и сопровождение электронной отчетности и электронного документооборота, а также дополнительных аналитических блоков по контрагентам и торгам.
СБИС: Проверка контрагентов
Система СБИС Контрагенты предоставляет полное досье на любую организацию, зарегистрированную в РФ. Досье включает включает сведения из ФНС, Росстата, ФАС РФ, ЦБ РФ и других официальных источников.
СБИС: Мониторинг электронных торгов
Система СБИС Торги собирает и постоянно обновляет информацию со всех федеральных и более 100 коммерческих площадок, помогает оценить конкурентов и победить в торгах. Доступны поиск и отбор торгов по различным параметрам.
После завершения формирования отчета, на третьем шаге, при нажатии кнопки «Передать на подпись» система выполняет форматно-логическую проверку файла и, в случае обнаружения ошибок, предлагает просмотреть протокол ошибок.
Нажатие на кнопку «Просмотреть протокол» открывает окно «Протокол проверки файла». Окне поделено на несколько частей. Для поиска ошибочного реквизита важны таблицы «Исходный файл» и «Список ошибок» и блоки данных «Подробное описание» и «Информация о формате».
Приведем несколько способов понимания/чтения протокола ошибок.
ВНИМАНИЕ! Начиная со сборки СБиС 2.4.369, перед началом ознакомления со способами по выявлению ошибок необходимо переключить «Режим отображения исходного файла» с «Ошибочные блоки» на «Файл целиком».
В таблице «Список ошибок» нажмем на строку с ошибкой. Под данной таблицей в подразделах «Подробное описание» и «Информация о формате» внимательно читаем описание ошибки. В представленном примере мы видим что ошибка в атрибуте «ДатаРожд», название реквизита «Дата рождения», раздела «Данные о физическом лице — получателя дохода». По указанным данным можно сделать вывод о том, что в данном разделе отчета отсутствует дата рождения физ. лица, либо она присутствует, но не соответствует требованиям предъявляемым к данному реквизиту. Далее ищем раздел с ошибчным реквизитом в отчете и исправляем.
Ниже пример определения местонахождения реквизита с ошибкой в самом отчете.
Нажатием в таблице «Список ошибок» на строку с ошибкой, автоматически выделяется строка в таблице «Исходный файл». Внимательно прочитав автоматически выделившуюся строку мы видим что в реквизите «ДатаРожд» после знака равно между кавычками отсутствует какой-либо показатель (цифры/буквы), хотя в реквизите «Статус» указано «1», а в реквизите «Гражд» указано «643». Найдя известные нам реквизиты («1» и «643») в отчете, между ними обнаружим реквизит с ошибкой.
Ниже пример определения местонахождения реквизита с ошибкой в самом отчете.
Встречаются ситуации когда способом №2 сложно определить местонахождение реквизита с ошибкой в отчете. В таких случаях мы ищем по строкам, расположенным выше или ниже автоматически выделившейся строки в таблице «Исходный файл», показатели уже известные нам (обычно это суммы, ставки, наименование чего-либо и другие).
Для перемещения по таблице «Исходный файл» используйте полосу прокрутки справа от таблицы.
Ниже пример определения местонахождения реквизита с ошибкой в самом отчете.
https://www. erpandcrm. ru/sbis_administration. ru/06/vozmoznie_o6ibki_i_ih_ispravlenie. htm
https://hultafors-russia. ru/ne-naydena-peremennaya-s-imenem-sbis/