Определение версии MySQL ODBC Connector

01.02.16

База данных - Инструменты администратора БД

Автоматическое определение установленной версии ODBC Connector MySQL из реестра Windows

При написании фоновых заданий на сервере x64 частенько сталкивался с тем, что трудно каждый раз подбирать название строки драйвера для MySQL, в результате родился вот такой незамысловатый кусочек кода:

    Список=ПолучитьСписокУстановленныхODBC();
    СтрокаДрайверов=СтроковыеФункцииКлиентСервер.ПолучитьСтрокуИзМассиваПодстрок(Список);
    СтрокаДрайвера=Неопределено;
    Если не Найти(нрег(СтрокаДрайверов), "mysql") Тогда
        //Нет драйвера, устанавливаем на клиенте
        #Если Клиент Тогда
        ВерсияWin=WindowsInfo();
        МакетКомпоненты=ПолучитьМакет("mySql"+Лев(ВерсияWin,3));
        ИмяФайлаУстановки=КаталогВременныхФайлов()+"driverMySQL.exe";
        МакетКомпоненты.Записать(ИмяФайлаУстановки);
        КомандаСистемы(ИмяФайлаУстановки);
        Сообщить("Пытаемся установить драйвер MySQL",СтатусСообщения.Важное);
        #Иначе
        ВызватьИсключение "На севере не установлен драйвер MySQL";
        #КонецЕсли
    Иначе
        МассивДрайверов=Новый СписокЗначений;
        МассивДрайверов.ЗагрузитьЗначения(Список);
        //Сортируем для использования старшей версии драйвера, если их установлено несколько
        МассивДрайверов.СортироватьПоЗначению(НаправлениеСортировки.Убыв);
        Для Каждого СтрДрайвер из МассивДрайверов Цикл
            Если Найти(нрег(СтрДрайвер.Значение), "mysql") Тогда
                Прервать;
            КонецЕсли;
        КонецЦикла;
    КонецЕсли;

Функцию ПолучитьСтрокуИзМассиваПодстрок можно взять из БСП. При работе на клиенте, при отсутсвии драйвера, будем ставить его автоматически из макета. Макет создаем из скачанного exe или msi файла с официального сайта. Для корректной установки на сервере, соответсвенно запускаем клиента с сервера, где выполняются фоновые задания 1С.

Далее обычное создание объекта:

    Соединение=Новый COMОбъект("ADODB.Connection");
    Порт = ?(ЗначениеЗаполнено(СтруктураПараметровСайта.Порт), СтруктураПараметровСайта.Порт, 3306);
    СтрокаСоединения= "
        |DRIVER={"+СокрЛП(СтрДрайвер)+"};
        |SERVER="+Сервер+";
        |DATABASE="+ИмяБазы+";
        |UID="+ИмяПользователя+";
        |PWD="+Пароль+"";

Собственно функция чтения установленных драйверов из реестра, для этого используем WMI:

Функция ПолучитьСписокУстановленныхODBC()

    Перем ODBCDrivers,Значения;
    
    WinMGMT = ПолучитьCOMОбъект("winmgmts:\\.\root\default:StdRegProv");
    HKLM = 2147483650;
    HKPath= "SOFTWARE\ODBC\ODBCINST.INI\ODBC Drivers\";
    WinMGMT.EnumValues(HKLM, HKPath, ODBCDrivers, Значения);
    Рез=Новый Массив;
    Для Каждого Драйвер из ODBCDrivers Цикл
        Рез.Добавить(Драйвер);
    КонецЦикла;
    Возврат Рез;

КонецФункции
Ну и элементарное определение через MSScriptControl версии windows, из-под которой мы работаем:
Функция WindowsInfo()
    
    ScrptCtrl=Новый COMОбъект("MSScriptControl.ScriptControl");
    ScrptCtrl.Language="vbscript";
    ScrptCtrl.AddCode("
    |Function GetOSVersion()
    |    strInfo=vbNullString
    |    For Each objOStype in GetObject(""winmgmts:"").InstancesOf (""Win32_ComputerSystem"")
    |       'WScript.Echo ""PC type = "" & objOStype.SystemType
    |       strInfo = strInfo & objOStype.SystemType & vbCrLf
    |    Next
    |    
    |    GetOSVersion=strInfo
    |End Function
    |");
    Возврат ScrptCtrl.Run("GetOSVersion");
КонецФункции

MySQL

См. также

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    14675    108    46    

108

Инструменты администратора БД Инструментарий разработчика Роли и права Программист Платформа 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

15000 руб.

10.11.2023    11964    45    33    

67

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 8.3.14 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 18.09.2024, версия 1.2

18000 руб.

06.12.2023    10748    47    8    

78

SALE! %

Инструментарий разработчика Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

4800 3840 руб.

14.01.2013    191352    1153    0    

920

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтер Пользователь Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    33868    108    152    

75

Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

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

3600 руб.

06.02.2017    32679    145    18    

51

Архивирование (backup) Инструменты администратора БД Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Данная разработка позволит решить вопрос с резервным копированием Ваших баз в автоматическом режиме, расположенных на сервере 1С. Система умеет ставить блокировки на вход, блокировать фоновые задания, принудительно отключать сеансы пользователей. И все это система делает в автоматически при создании бэкапа (или через команду). Выгрузка происходит в родной формат 1С - .dt. Так же система умеет архивировать данные выгрузки с установкой пароля. Умеет менять расширение файла zip или dt на любое указанное вами, что позволит сохранить выгрузки от шифровальщика. Может удалять старые копии выгрузок, оставляя указанное количество резервных копий, начиная с самой поздней. Только для WINDOWS!

6000 руб.

06.11.2012    73779    629    45    

88

Инструменты администратора БД Пользователь Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Платные (руб)

Многие сталкиваются с проблемой когда изображения, находящиеся в базе разные по объему и размерам. Менеджеры могут добавить файлы в очень высоком разрешении, объемом свыше 20 Мегабайт. База данных становится слишком большой, выгрузка на сайт идёт медленно и требуется много место на хостинге. Как сжать картинки и уменьшить размер базы 1С? Это можно сделать с помощью данной обработки. Существует возможность выбрать различные варианты для того чтобы уменьшить картинки: в разы, в процентах от первоначального объема, а также сделать картинки одинаковой ширины. В результате размер базы 1С значительно сократится (в зависимости от количества и размера картинок), а изображения станут небольшого объема, равными по ширине, почти без потери качества. Работает на управляемых формах для УТ 11, КА, ERP.

3000 руб.

21.07.2022    10181    10    4    

18
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. cool.vlad4 2 01.02.16 20:55 Сейчас в теме
Версию винды ЕМНИП через Новый СистемнаяИнформация (ВерсияОС , ТипПлатформы) можно получить.
2. spawn_a 55 02.02.16 09:30 Сейчас в теме
(1) cool.vlad4, Да всё верно, но в клиентском контексте это будет x32. В серверном будет - x64. Но если разные сервера для клиентского сеанса и фоновых заданий, то опять таки не то. Плюс сервер обслуживающий клиентов, вообще может под линухом крутиться.
cool.vlad4; +1 Ответить
Оставьте свое сообщение