Импорт из Базы данных SQL Azure

В этой статье описывается, как использовать модуль Import Data (импорт данных ) в машинное обучение Azure Studio (классическая модель) для получения данных из базы данных SQL Azure или хранилища данных SQL Azure.

Примечание

Применимо к: машинное обучение Studio (классическая модель)

Это содержимое относится только к Studio (классическая модель). Аналогичные модули перетаскивания были добавлены в конструктор Машинное обучение Azure. Дополнительные сведения см. в статье сравнение двух версий.

Чтобы импортировать данные из базы данных, необходимо указать как имя сервера, так и имя базы данных, а также инструкцию SQL, определяющую таблицу, представление или запрос.

Как правило, хранение данных в базах данных Azure требует больших затрат, чем использование таблиц или больших двоичных объектов в Azure. В зависимости от типа подписки могут быть также ограничены объемы данных, которые можно хранить в базе данных. Однако для базы данных SQL Azure не взимается плата за транзакции, поэтому этот вариант идеально подходит для быстрого доступа к меньшим объемам часто используемых данных, таким как таблицы подстановки данных или словари данных.

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

Импорт данных из базы данных SQL Azure или хранилища данных SQL

Использование мастера импорта данных

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

  1. Добавьте модуль Импорт данных в эксперимент. Модуль можно найти в Studio (классическая модель) в категории входные и выходные данные .

  2. Щелкните запустить мастер импорта данных и следуйте инструкциям.

  3. После завершения настройки, чтобы фактически скопировать данные в эксперимент, щелкните модуль правой кнопкой мыши и выберите команду Выполнить выбранное.

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

Установка свойств вручную в модуле "Импорт данных"

Следующие шаги описывают настройку источника импорта вручную.

  1. Добавьте модуль Импорт данных в эксперимент. Этот модуль можно найти в студии (классическая модель) в категории входные и выходные данные .

  2. В качестве источника данных выберите база данных SQL Azure.

  3. Задайте следующие параметры, относящиеся к базе данных SQL Azure или хранилищу данных SQL Azure.

    Имя сервера базы данных: введите имя сервера, создаваемое Azure. Как правило, оно представлено в виде <generated_identifier>.database.windows.net.

    Имя базы данных: введите имя существующей базы данных на сервере, который вы только что указали.

    Имя учетной записи пользователя сервера: введите имя пользователя учетной записи, имеющей разрешения на доступ к базе данных.

    Пароль учетной записи пользователя сервера: укажите пароль для указанной учетной записи пользователя.

    Запрос к базе данных: введите или вставьте инструкцию SQL, описывающую данные, которые необходимо считать. Всегда проверяйте инструкцию SQL и сначала проверяйте результаты запроса, используя такие средства, как Visual Studio обозреватель сервера или SQL Server Data Tools.

    Примечание

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

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

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

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

  5. Запустите эксперимент.

    Так как Импорт данных загружает данные в Studio (классическая модель), некоторые неявные преобразования типов также могут быть выполнены в зависимости от типов данных, используемых в базе данных-источнике.

Результаты

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

При необходимости можно изменить набор данных и его метаданные с помощью средств в Studio (классическая модель):

  • Используйте команду изменить метаданные , чтобы изменить имена столбцов, преобразовать столбец в другой тип данных или указать, какие столбцы являются метками или компонентами.

  • Для выбора подмножества столбцов используйте команду Выбор столбцов в наборе данных .

  • Используйте Partition и Sample для разделения набора данных по критериям или получения n верхних строк.

Примеры

Пример использования данных из баз данных Azure в машинном обучении см. в следующих статьях и экспериментах:

Технические примечания

В этом разделе содержатся сведения о реализации, советы и ответы на часто задаваемые вопросы.

Часто задаваемые вопросы

Можно ли фильтровать данные по мере их считывания из источника?

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

Примечание

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

Почему возникает ошибка «тип Decimal не поддерживается»?

При чтении данных из базы данных SQL может появиться сообщение об ошибке, сообщающее о неподдерживаемом типе данных.

Если данные, получаемые из базы данных SQL, содержат типы данных, которые не поддерживаются в Машинное обучение Azure, перед чтением данных следует привести или преобразовать десятичные числа в поддерживаемые данные. Импорт данных не может автоматически выполнять преобразования, которые приведут к утрате точности.

Дополнительные сведения о поддерживаемых типах данных см. в разделе типы данных модулей.

Что произойдет, если база данных находится в другом географическом регионе. Может ли импортировать данные по-прежнему получать доступ к базе данных? Где хранятся данные?

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

Данные, которые вы читаете в рабочую область для эксперимента, сохраняются в учетной записи хранения, связанной с экспериментом.

Почему некоторые символы отображаются неправильно?

Машинное обучение Azure поддерживает кодировку UTF-8. Если в строковых столбцах базы данных используется другая кодировка, символы могут быть неправильно импортированы.

Один из вариантов — экспорт данных в CSV-файл в службе хранилища Azure и использование CSV-файла с параметром Encoding для указания параметров для пользовательских разделителей, кодовой страницы и т. д.

Параметры модуля

Имя Диапазон Тип По умолчанию Описание
Источник данных Список Источник данных или приемник хранилище BLOB-объектов Azure Источник данных может быть HTTP, FTP, анонимным HTTPS или FTPS, файлом в хранилище BLOB-объектов Azure, таблицей Azure, базой данных SQL Azure, локальной SQL Server базой данных, таблицей Hive или конечной точкой OData.
URI HDFS-сервера any Строка нет Конечная точка RESTful HDFS
Имя сервера базы данных any Строка нет Имя учетной записи хранения Azure
Имя базы данных any SecureString нет Ключ к хранилищу Azure
Имя учетной записи пользователя сервера any Строка нет Имя контейнера Azure
Имя учетной записи пользователя сервера Список (подмножество) Содержимое URL-адреса OData Тип формата данных
Запрос к базе данных any Строка нет Тип формата данных
Использование кэшированных результатов True или false Логическое Ложь. description

Выходные данные

Имя Type Описание
Набор данных результатов Таблица данных Набор данных с загруженными данными

Исключения

Исключение Описание
Ошибка 0027 Исключение возникает, если два объекта должны быть одинакового размера, но это не так.
Ошибка 0003 Исключение возникает, если один или несколько входных аргументов имеют значение NULL или пусты.
Ошибка 0029 Исключение возникает при передаче недопустимого универсального кода ресурса.
Ошибка 0030 Исключение возникает, когда не удается скачать файл.
Ошибка 0002 Исключение возникает, если один или несколько параметров не удалось проанализировать или преобразовать из заданного типа в необходимый для целевого метода тип.
Ошибка 0009 Исключение возникает, если имя учетной записи хранилища Azure или имя контейнера указаны неверно.
Ошибка 0048 Исключение возникает, когда не удается открыть файл.
Ошибка 0015 Исключение возникает, если произошел сбой подключения к базе данных.
Ошибка 0046 Исключение возникает, если не удается создать каталог по указанному пути.
Ошибка 0049 Исключение возникает, когда не удается проанализировать файл.

Список ошибок, относящихся к модулям студии (классическая версия), см. в разделе машинное обучение коды ошибок.

Список исключений API см. в разделе Машинное обучение REST API коды ошибок.

См. также раздел

Импорт данных
Экспорт данных
Импорт из URL-адреса через HTTP
Импорт из запроса Hive
Импорт из таблицы Azure
Импорт из хранилища BLOB-объектов Azure
Импорт из поставщиков веб-каналов данных
Импорт из локальной базы данных SQL Server