RDT1C/DataProcessors/ирСтруктураХраненияБД/Ext/ObjectModule.bsl
Администратор e2082add8d Консоль запросов
*Исправлена ошибка команды "Структура формы"
    Административная регистрация com-компонент
        +Добавлена кнопка "Запустить от имени администратора"
        *Исправлено выполнение административной регистрации под пользователем домена, являющимся локальным администратором
    Общее
        *Устранены проблемы с антивирусным ПО путем возврата к использованию старой версии утилиты hstart
    Подбор и обработка объектов
        +В схему компоновки добавлены поля-функции ТИПЗНАЧЕНИЯ() от полей составных типов

3.78
    Консоль запросов
        *Устранено ошибочное использование параметров в фигурных скобках при наличии параметра с типом "Выражение СКД"
        +В подменю "Вставка" для поля текста запроса добавлена команда "Ссылка из буфера"
        *Исправлено вычисление значений параметров для вложенных компоновок из макета компоновки
        *Исправлено некорректное извлечение вычисляемых параметров из макета компоновки
    Конструктор запроса
        +Добавлена поддержка типа запроса TRUNCATE TABLE
        +Для запроса типа WQL при двойном клике на доступном поле доступной таблицы поле теперь добавляется в выбранные поля
    Анализ журнала регистрации
        +Реализованы команды сортировки для списков значений отбора
        *Исправлено долгое обновление табличного поля отбора с большими списками
    Динамический список
        *В командую панель возвращены все стандартные кнопки
        *При открытии с установкой таблицы фокус ввода теперь устанавливается в табличное поле
    Редактор объекта БД
        *Инструмент "Поиск ссылок на объект" перенесен сюда в виде закладки
        +Добавлена поддержка перечислений и точек маршрута
    Интерфейсная панель
        *Исправлены ошибки при обработке веток не метаданных
    Общее
        +Обновлено внутренне описание платформы от версии 8.3.9
        *Исправлены ошибки при открытии ссылок в режиме совместимости 8.1
        *Обеспечена компипяция в режиме совместимости 8.3.9
        *Кнопка открытия настроек справочника Алгоритмы перенесена с общей панели инструментов в формы списка справочника
    Различные значения колонки
        *Исправлены ошибки при обработке булевых колонок
    Консоль кода
        +В подменю "Вставка" добавлена команда "Ссылка из буфера"
    Поиск дублей и замена ссылок
        *Исправлен учет равенства реквизитов при поиске по похожим словам
    Структура хранения БД
        *Исправлена ошибка при нажатии "Показать индекс" в контекстном меню таблицы "Наборы полей" на закладке "Индексы"
    Поиск ссылок на объект
        *Перенесен в инструмент "Редактор объекта БД" в виде закладки

3.77
    Общее
        *Элевация оставлена только в форме административной регистрации COM-компонент, в настройке техножурнала и при изменении параметров служб сервера 1С
        *Элевация теперь используется только если у учетной записи Windows есть административные права
        *Улучшены сообщения пользователю при проблемах регистрации COM компонент
        *Открытие формы объекта по двойному клику на ячейках табличных полей теперь выполняется без получения объекта
        *Улучшена установка ширины динамически добавляемых колонок табличных полей
    Административная регистрация COM компонент
        +Добавлены кнопки "Снять флажки" и "Установить флажки"
    Редактор объекта БД
        *Исправлено распознавание ссылки документа по представлению в поле выбора объекта
        *Исправлено переключение режима редактирования независимого регистра при изменении отбора командами "снять все" и "установить все"
    Динамический список
        *При открытии редактора объекта БД для добавления в независимый регистр сведений теперь включаются все элементы отбора
    Консоль запросов
        *Устранена ошибочная доступность для изменения флажков в коллекции результата запроса
        *Исправлена ошибка загрузки результата WQL запроса

3.76
    Управление службами сервера 1С
        *Улучшена диагностика ошибок
        +Добавлена элевация при изменении параметров служб
    Динамический список
        *Устранено свежее скрытие колонки со стандартной картинкой
    Интерфейсная панель
        +Добавлены перечисления
    Консоль запросов
        *Исправлена ошибка загрузки пустого результата запроса MSSQL
    Редактор констант
        +Включение функциональных опций теперь изменяет только булевы константы и не выполняет их запись
        *Реализован пропуск ошибок записи констант
    Конструктор запросов
        *Устранена ошибочная виртуальная таблица 1С ЗадачиПоИсполнителю  у задачи без адресации
    Редактор объекта БД
        *Флажок "Очищать по отбору чтения" теперь становится доступным только если в считанном наборе записей были строки
        +В режиме менеджера записи регистра сведений реализовано удаление
        *Исправлена свежая ошибка параметризованного открытия строки независимого регистра сведений
    Общее
        *Исправлена ошибка нажатия "Запустить обычное приложение" в тонком клиенте из формы "Невозможно выполнить действие"
2016-12-04 00:30:12 +03:00

265 lines
19 KiB
Plaintext
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

//ирПортативный Перем ирПортативный Экспорт;
//ирПортативный Перем ирОбщий Экспорт;
//ирПортативный Перем ирСервер Экспорт;
//ирПортативный Перем ирКэш Экспорт;
//ирПортативный Перем ирПривилегированный Экспорт;
Перем мПлатформа Экспорт;
Перем мСтруктураХраненияSDBL Экспорт;
Перем мСтруктураХраненияСУБД Экспорт;
Перем мКомпонентаCDDB;
Перем мИменаДополнительныхТаблиц Экспорт;
Процедура ОбновитьТаблицы() Экспорт
Таблицы.Очистить();
Индексы.Очистить();
// Антибаг 8.3.7-8.3.8 https://partners.v8.1c.ru/forum/topic/1486259 Выполнение метода ПолучитьСтруктуруХраненияБазаДанных с фильтром, включающим строку "Константы", приводит к ошибке
Если Истина
И ОтборПоМетаданным <> Неопределено
И ирКэш.Получить().ВерсияПлатформы > 803001
И Метаданные.РежимСовместимости = Метаданные.СвойстваОбъектов.РежимСовместимости.Версия8_2_13
Тогда
ИндексТаблицы = ОтборПоМетаданным.Найти("Константы");
Если ИндексТаблицы <> Неопределено Тогда
ОтборПоМетаданным.Удалить(ИндексТаблицы);
Сообщить("Таблица Константы удалена из фильтра из-за ошибка платформы 8.3");
КонецЕсли;
КонецЕсли;
Если ПоказыватьSDBL Тогда
Если ОтборПоМетаданным = Неопределено Тогда
мСтруктураХраненияSDBL = ирКэш.ПолучитьСтруктуруХраненияБДЛкс(Ложь);
Иначе
мСтруктураХраненияSDBL = ирОбщий.ПолучитьСтруктуруХраненияБДЛкс(ОтборПоМетаданным, Ложь);
КонецЕсли;
ЗаполнитьТаблицыИзСтруктурыХранения(мСтруктураХраненияSDBL, Ложь);
КонецЕсли;
Если ПоказыватьСУБД Тогда
Если ОтборПоМетаданным = Неопределено Тогда
мСтруктураХраненияСУБД = ирКэш.ПолучитьСтруктуруХраненияБДЛкс(Истина);
Иначе
мСтруктураХраненияСУБД = ирОбщий.ПолучитьСтруктуруХраненияБДЛкс(ОтборПоМетаданным, Истина);
КонецЕсли;
ЗаполнитьТаблицыИзСтруктурыХранения(мСтруктураХраненияСУБД, Истина);
КонецЕсли;
РезультирующееПоказыватьРазмеры = ПоказыватьРазмеры И ПоказыватьСУБД;
Если РезультирующееПоказыватьРазмеры Тогда
Если ирКэш.ЭтоФайловаяБазаЛкс() Тогда
ЗаполнитьРазмерыФайлойБазы();
Иначе
ЗаполнитьРазмерыБазыMSSQL();
КонецЕсли;
КонецЕсли;
Таблицы.Сортировать("Метаданные, ИмяТаблицы, Назначение, ИмяТаблицыХранения, СУБД");
Индексы.Сортировать("Метаданные, ИмяТаблицы, Назначение, ИмяТаблицыХранения, ИмяИндекса, ИмяИндексаХранения, СУБД");
КонецПроцедуры
Процедура ЗаполнитьРазмерыБазыMSSQL()
СоединениеADO = ирОбщий.ПолучитьСоединениеСУБД();
Если СоединениеADO = Неопределено Тогда
Возврат;
КонецЕсли;
ТекстЗапроса = ПолучитьМакет("ЗапросРазмеров").ПолучитьТекст();
РезультатЗапроса = Новый COMОбъект("ADODB.Recordset");
adOpenStatic = 3;
adLockOptimistic = 3;
adCmdText = 1;
РезультатЗапроса.Open(ТекстЗапроса, СоединениеADO, adOpenStatic, adLockOptimistic, adCmdText);
//Если СоединениеADO.Properties("Multiple Results").Value <> 0 Тогда
// // Получаем последний результат пакетной команды
// Пока Истина Цикл
// лРезультат = РезультатЗапроса.NextRecordset();
// Если лРезультат = Неопределено Тогда
// Прервать;
// КонецЕсли;
// РезультатЗапроса = лРезультат;
// КонецЦикла;
//КонецЕсли;
ADOUtils = мПлатформа.ПолучитьADOUtils(Истина, , Истина);
ТаблицаРезультата = ADOUtils.ADORecordsetToValueTable(РезультатЗапроса);
Если ОбщаяТаблицаИндексов Тогда
Для Каждого СтрокаРезультата Из ТаблицаРезультата Цикл
КлючПоиска = Новый Структура("НИмяТаблицыХранения, НИмяИндексаХранения", НРег(СтрокаРезультата.TableName), НРег(СтрокаРезультата.IndexName));
СтрокиИндекса = Индексы.НайтиСтроки(КлючПоиска);
Если СтрокиИндекса.Количество() = 0 Тогда
Если ОтборПоМетаданным <> Неопределено Тогда
Продолжить;
КонецЕсли;
СтрокаИндекса = Индексы.Добавить();
ЗаполнитьЗначенияСвойств(СтрокаИндекса, КлючПоиска);
СтрокаИндекса.ИмяИндексаХранения = СтрокаРезультата.IndexName;
СтрокаИндекса.ИмяИндекса = СтрокаРезультата.IndexName;
СтрокаИндекса.ИмяТаблицыХранения = СтрокаРезультата.TableName;
СтрокаИндекса.ИмяТаблицы = мИменаДополнительныхТаблиц[ВРег(СтрокаРезультата.TableName)];
Если Не ЗначениеЗаполнено(СтрокаИндекса.ИмяТаблицы) Тогда
СтрокаИндекса.ИмяТаблицы = СтрокаРезультата.TableName;
КонецЕсли;
СтрокаИндекса.Назначение = СтрокаИндекса.ИмяТаблицы;
СтрокаИндекса.СУБД = Истина;
Иначе
СтрокаИндекса = СтрокиИндекса[0];
КонецЕсли;
СтрокаИндекса.ТипИндекса = СтрокаРезультата.IndexType;
СтрокаИндекса.РазмерИндексы = СтрокаРезультата.IndexKB;
СтрокаИндекса.РазмерОбщий = СтрокаРезультата.ReservedKB;
КонецЦикла;
КонецЕсли;
ТаблицаРезультата.Свернуть("TableName", "IndexKB, ReservedKB, DataKB, Rows");
Для Каждого СтрокаРезультата Из ТаблицаРезультата Цикл
СтрокаТаблицы = Таблицы.Найти(НРег(СтрокаРезультата.TableName), "НИмяТаблицыХранения");
Если СтрокаТаблицы = Неопределено Тогда
Если ОтборПоМетаданным <> Неопределено Тогда
Продолжить;
КонецЕсли;
СтрокаТаблицы = Таблицы.Добавить();
СтрокаТаблицы.ИмяТаблицыХранения = СтрокаРезультата.TableName;
СтрокаТаблицы.НИмяТаблицыХранения = НРег(СтрокаТаблицы.ИмяТаблицыХранения);
СтрокаТаблицы.ИмяТаблицы = мИменаДополнительныхТаблиц[ВРег(СтрокаРезультата.TableName)];
Если Не ЗначениеЗаполнено(СтрокаТаблицы.ИмяТаблицы) Тогда
СтрокаТаблицы.ИмяТаблицы = СтрокаРезультата.TableName;
КонецЕсли;
СтрокаТаблицы.Назначение = СтрокаТаблицы.ИмяТаблицы;
СтрокаТаблицы.СУБД = Истина;
КонецЕсли;
СтрокаТаблицы.РазмерИндексы = СтрокаРезультата.IndexKB;
СтрокаТаблицы.РазмерОбщий = СтрокаРезультата.ReservedKB;
СтрокаТаблицы.КоличествоСтрок = СтрокаРезультата.Rows;
СтрокаТаблицы.РазмерЗаписи = СтрокаРезультата.DataKB;
КонецЦикла;
КонецПроцедуры
Процедура ЗаполнитьРазмерыФайлойБазы()
Компонента1CD = мПлатформа.ПолучитьОбъектВнешнейКомпонентыИзМакета("_1CDLib", "T1CDLib.DB1CD", "T1CDLib", ТипВнешнейКомпоненты.Native);
ПапкаОб = НСтр(СтрокаСоединенияИнформационнойБазы(), "File");
ИмяЛога = ПапкаОб + "\logdb1cd.log";
ИмяФайла = ПапкаОб + "\1cv8.1cd";
мКомпонентаCDDB = Новый("AddIn.T1CDLib.DB1CD");
мКомпонентаCDDB.LogLevel=0;
мКомпонентаCDDB.FileOpeningMode=3;
//FileDB.OpenLogFile(ИмяЛога);
#Если Клиент Тогда
Состояние("Чтение структуры файла");
#КонецЕсли
мКомпонентаCDDB.Open1CDFile(ИмяФайла);
мКомпонентаCDDB.OpenMetadata();
ВерсияБД = мКомпонентаCDDB.BaseVersion;
//Элементы.НадписьВерсияБД.Заголовок="Версия БД: "+ВерсияБД;
ArrayPres = мКомпонентаCDDB.GetTablesArray(Ложь);
TablesArray = ЗначениеИзСтрокиВнутр(ArrayPres);
Для TabInd = 1 По TablesArray.Count() Цикл
TableInfo = TablesArray[TabInd-1];
СтрокаТаблицы = Таблицы.Найти(НРег(TableInfo.Name), "НИмяТаблицыХранения");
Если СтрокаТаблицы = Неопределено Тогда
Если ОтборПоМетаданным <> Неопределено Тогда
Продолжить;
КонецЕсли;
СтрокаТаблицы = Таблицы.Добавить();
//ТекСтр.НомерПП = TabInd;
СтрокаТаблицы.ИмяТаблицыХранения = TableInfo.Name;
СтрокаТаблицы.НИмяТаблицыХранения = НРег(СтрокаТаблицы.ИмяТаблицыХранения);
СтрокаТаблицы.ИмяТаблицы = мИменаДополнительныхТаблиц[ВРег(TableInfo.Name)];
Если Не ЗначениеЗаполнено(СтрокаТаблицы.ИмяТаблицы) Тогда
СтрокаТаблицы.ИмяТаблицы = TableInfo.Name;
КонецЕсли;
СтрокаТаблицы.Назначение = СтрокаТаблицы.ИмяТаблицы;
СтрокаТаблицы.СУБД = Истина;
//ТекСтр.НазначениеТаблицы = ПолучитьТипТаблицы(TableInfo.Name);
//ТекСтр.ОписаниеТаблицы=TablePres;
КонецЕсли;
СтрокаТаблицы.РазмерЗаписи = Окр(мКомпонентаCDDB.GetObjectSize(TableInfo.RecordsIndex) / 1024);
СтрокаТаблицы.РазмерБлоб = Окр(мКомпонентаCDDB.GetObjectSize(TableInfo.BlobIndex) / 1024);
СтрокаТаблицы.РазмерИндексы = Окр(мКомпонентаCDDB.GetObjectSize(TableInfo.IndexesIndex) / 1024);
СтрокаТаблицы.РазмерОбщий = СтрокаТаблицы.РазмерЗаписи + СтрокаТаблицы.РазмерБлоб + СтрокаТаблицы.РазмерИндексы;
Если ПоказыватьУдаленные Тогда
ПолучитьРазмерУдалДанных(TableInfo.Name, СтрокаТаблицы);
КонецЕсли;
КонецЦикла;
мКомпонентаCDDB.CloseFile();
мКомпонентаCDDB.CloseLogFile();
КонецПроцедуры
Функция ПолучитьРазмерУдалДанных(TabName,ТекСтр)
РазмерУдал=0;
РазмерУдалБлоб=0;
Если мКомпонентаCDDB.OpenTable(0,TabName) Тогда
РазмерУдалБлоб=мКомпонентаCDDB.GetDelBlobDataLength(0);
Рез=мКомпонентаCDDB.MoveToRecord(0,0);
NextInd=мКомпонентаCDDB.GetNextDelRecordIndex(0);
КолвоУдал=0;
Пока Рез И (NextInd>0) Цикл
КолвоУдал=КолвоУдал+1;
Рез=мКомпонентаCDDB.MoveToRecord(0,NextInd);
NextInd=мКомпонентаCDDB.GetNextDelRecordIndex(0);
КонецЦикла;
РазмерУдал=КолвоУдал*мКомпонентаCDDB.GetTableRecordLength(0);
КонецЕсли;
мКомпонентаCDDB.CloseTable(0);
ТекСтр.РазмерУдаленЗаписи=РазмерУдал;
ТекСтр.РазмерУдаленБлоб=РазмерУдалБлоб;
ТекСтр.РазмерУдаленОбщий=ТекСтр.РазмерУдаленЗаписи+ТекСтр.РазмерУдаленБлоб;
Возврат Истина;
КонецФункции
Процедура ЗаполнитьТаблицыИзСтруктурыХранения(Знач СтруктураХранения, ЭтоСУБД)
#Если Сервер И Не Сервер Тогда
СтруктураХранения = Новый ТаблицаЗначений;
#КонецЕсли
Индикатор = ирОбщий.ПолучитьИндикаторПроцессаЛкс(СтруктураХранения.Количество(), "Структура " + ?(ЭтоСУБД, "СУБД", "SDBL"));
Для Каждого СтрокаСтруктурыХранения Из СтруктураХранения Цикл
ирОбщий.ОбработатьИндикаторЛкс(Индикатор);
СтрокаТаблицы = Таблицы.Добавить();
ЗаполнитьЗначенияСвойств(СтрокаТаблицы, СтрокаСтруктурыХранения);
СтрокаТаблицы.Поля = СтрокаСтруктурыХранения.Поля.Количество();
СтрокаТаблицы.Индексы = СтрокаСтруктурыХранения.Индексы.Количество();
СтрокаТаблицы.СУБД = ЭтоСУБД;
СтрокаТаблицы.НИмяТаблицыХранения = НРег(СтрокаТаблицы.ИмяТаблицыХранения);
Если ОбщаяТаблицаИндексов Тогда
Для Каждого СтрокаХраненияИндекса Из СтрокаСтруктурыХранения.Индексы Цикл
СтрокаИндекса = Индексы.Добавить();
ЗаполнитьЗначенияСвойств(СтрокаИндекса, СтрокаТаблицы);
СтрокаИндекса.ИмяИндекса = ирОбщий.ПолучитьПредставлениеИндексаХраненияЛкс(СтрокаХраненияИндекса, СтрокаТаблицы.СУБД, СтрокаСтруктурыХранения);
СтрокаИндекса.ИмяИндексаХранения = СтрокаХраненияИндекса.ИмяИндексаХранения;
СтрокаИндекса.Поля = СтрокаХраненияИндекса.Поля.Количество();
СтрокаИндекса.НИмяИндексаХранения = НРег(СтрокаИндекса.ИмяИндексаХранения);
СтрокаИндекса.НИмяТаблицыХранения = НРег(СтрокаИндекса.ИмяТаблицыХранения);
КонецЦикла;
КонецЕсли;
КонецЦикла;
ирОбщий.ОсвободитьИндикаторПроцессаЛкс();
КонецПроцедуры
//ирПортативный #Если Клиент Тогда
//ирПортативный Контейнер = Новый Структура();
//ирПортативный Оповестить("ирПолучитьБазовуюФорму", Контейнер);
//ирПортативный Если Не Контейнер.Свойство("ирПортативный", ирПортативный) Тогда
//ирПортативный ПолноеИмяФайлаБазовогоМодуля = ВосстановитьЗначение("ирПолноеИмяФайлаОсновногоМодуля");
//ирПортативный ирПортативный = ВнешниеОбработки.ПолучитьФорму(ПолноеИмяФайлаБазовогоМодуля);
//ирПортативный КонецЕсли;
//ирПортативный ирОбщий = ирПортативный.ПолучитьОбщийМодульЛкс("ирОбщий");
//ирПортативный ирКэш = ирПортативный.ПолучитьОбщийМодульЛкс("ирКэш");
//ирПортативный ирСервер = ирПортативный.ПолучитьОбщийМодульЛкс("ирСервер");
//ирПортативный ирПривилегированный = ирПортативный.ПолучитьОбщийМодульЛкс("ирПривилегированный");
//ирПортативный #КонецЕсли
мПлатформа = ирКэш.Получить();
мИменаДополнительныхТаблиц = Новый Соответствие;
мИменаДополнительныхТаблиц.Вставить("CONFIG", "КонфигурацияБД");
мИменаДополнительныхТаблиц.Вставить("CONFIGSAVE", "СохранённаяКонфигурация");
мИменаДополнительныхТаблиц.Вставить("DBSCHEMA", "СхемаБД");
мИменаДополнительныхТаблиц.Вставить("FILES", "Файлы");
мИменаДополнительныхТаблиц.Вставить("PARAMS", "Параметры");
мИменаДополнительныхТаблиц.Вставить("V8USERS", "Пользователи");
мИменаДополнительныхТаблиц.Вставить("IBVERSION", "ВерсияИБ");