Поделиться через


Подключение к базе данных SQL с помощью C и C++

Применимо к: База данных SQL Azure

Эта статья помогает разработчикам C и C++ подключаться к База данных SQL Azure.

Необходимые компоненты

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

  • Активная учетная запись Azure. Если у вас нет такой учетной записи, вы можете зарегистрироваться для использования бесплатной пробной версии Azure.
  • Visual Studio. Для разработки и запуска этого примера необходимо установить компоненты языка C++.
  • Инструменты разработки Visual Studio для Linux. Если вы разрабатываете приложение на платформе Linux, необходимо также установить расширение Linux для Visual Studio.

Технологии доступа к данным: ODBC и OLE DB

В настоящее время существует два способа подключения к База данных SQL Azure: ODBC (open Database Connectivity) и OLE DB (база данных связывания объектов и внедрение базы данных). В последние годы корпорация Майкрософт поддерживает ODBC для доступа к собственным реляционным данным. ODBC гораздо быстрее, чем OLE DB. Единственное предостережение — ODBC использует старый API в стиле C.

Создание Базы данных SQL Azure

Чтобы узнать, как создать образец базы данных, перейдите на страницу Начало работы .

Получение строки подключения

После подготовки Базы данных SQL Azure необходимо выполнить следующие действия, чтобы найти информацию о подключении и добавить IP-адрес клиента для доступа через брандмауэр.

  1. На портале Azure перейдите к строкам подключения вашей базы данных Azure SQL, используя Показать строки подключения к базе данных, перечисленные в разделе Обзор вашей базы данных.

    Снимок экрана портала Azure, показывающего страницу обзора базы данных SQL. Выделена ссылка

  2. Выберите вкладку ODBC .

    Снимок экрана строки подключения ODBC из портала Azure.

  3. Скопируйте содержимое строки ODBC (включает Node.js) [проверка подлинности SQL]. Оно будет использоваться позже для подключения из интерпретатора командной строки ODBC C++. Эта строка содержит такие сведения, как драйвер, сервер и другие параметры подключения к базе данных.

Добавление IP-адреса в брандмауэр

  1. Перейдите на логический сервер Базы данных SQL Azure. Выберите ссылку на имя сервера на странице обзора базы данных SQL или перейдите к ней через поиск на портале Azure.
  2. В разделе "Безопасность" выберите "Сеть".
  3. На вкладке "Общедоступный доступ" выберите выбранные сети , если это еще не так.
  4. Добавьте IP-адрес клиента в брандмауэр, выполнив следующие действия , чтобы убедиться, что мы можем установить успешное подключение. Выберите "Добавить адрес IPv4 клиента" или добавьте правило брандмауэра.

На этом этапе вы настроили базу данных SQL Azure и готовы подключиться из кода C++ с рабочей станции.

Подсказка

Добавление IP-адреса рабочей станции клиента в брандмауэр общедоступной сети допустимо для временной лаборатории или настройки обучения, но для корпоративного решения или длительного проекта выполните следующие рекомендации по обеспечению безопасности:

  • Установите разрешение службам и ресурсам Azure доступ к этому серверу на значение OFF на уровне сервера.
  • Используйте конечные точки службы виртуальной сети и правила брандмауэра виртуальной сети.
  • Используйте Приватный канал.

Подключение из приложения Windows C/C++

К Базе данных SQL Azure можно подключиться при помощи ODBC в Windows с использованием этого примера, созданного с использованием Visual Studio. В этом примере используется интерпретатор командной строки ODBC, с помощью которого можно подключиться к Базе данных SQL Azure. Данный пример принимает в качестве аргумента командной строки файл с именем базы данных-источника (DSN) или подробную строку подключения, скопированную на портале Azure ранее. Откройте страницу свойств для этого проекта и вставьте строку подключения в качестве аргумента команды, как показано ниже:

Файл свойств DSN.

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

Запустите приложение, чтобы создать его. Должно появиться следующее окно, подтверждающее успешность подключения. Вы даже можете выполнить некоторые основные команды SQL, например CREATE TABLE проверить подключение к базе данных:

Снимок экрана подключений C++ в odbcsql.exe.

Кроме того, файл DSN можно создать при помощи мастера, который запускается, если не указаны аргументы командной строки. Рекомендуется попробовать и этот вариант. Этот файл DSN можно использовать для автоматизации и защиты параметров проверки подлинности:

Снимок экрана: процесс создания файла DSN на странице выбора источника данных.

Поздравляем! Вы успешно установили подключение к базе данных SQL Azure при помощи C++ и ODBC в Windows. Чтобы сделать то же самое для платформы Linux, см. сведения дальше в этой статье.

Подключение из приложения Linux C/C++

Вы можете разрабатывать приложения C++ Linux в Visual Studio. Дополнительные сведения см. в следующем блоге: Visual C++ для разработки Linux.

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

В этом руководстве предполагается, что у вас есть дистрибутив Ubuntu 16.04 Linux. Действия также применяются к Ubuntu 15.10, Red Hat 6 и Red Hat 7.

С помощью следующих действий устанавливаются библиотеки, необходимые вашему дистрибутиву для SQL и ODBC:

    sudo su
    sh -c 'echo "deb [arch=amd64] https://apt-mo.trafficmanager.net/repos/mssql-ubuntu-test/ xenial main" > /etc/apt/sources.list.d/mssqlpreview.list'
    sudo apt-key adv --keyserver apt-mo.trafficmanager.net --recv-keys 417A0893
    apt-get update
    apt-get install msodbcsql
    apt-get install unixodbc-dev-utf16 #this step is optional but recommended*

Запустите Visual Studio. В разделе "Сервис ->Параметры> - кроссплатформенный>диспетчер соединений" добавьте подключение к вашему окну Linux:

Снимок экрана: параметры инструментов для создания и удаления подключений SSH.

После того как установлено подключение по протоколу SSH, создайте шаблон пустого проекта (Linux):

Снимок экрана: шаблоны для новых проектов.

Затем можно добавить новый исходный файл C и заменить его этим содержимым. Используя API SQLAllocHandleSQLSetConnectAttrODBC, и SQLDriverConnectвы сможете инициализировать и установить подключение к базе данных.

Как и в примере Windows ODBC, необходимо заменить вызов SQLDriverConnect на сведения из параметров строки подключения к базе данных, которые были скопированы ранее с портала Azure.

     retcode = SQLDriverConnect(
        hdbc, NULL, "Driver=ODBC Driver 13 for SQL"
                    "Server;Server=<yourserver>;Uid=<yourusername>;Pwd="
                    "<password>;database=<yourdatabase>",
        SQL_NTS, outstr, sizeof(outstr), &outstrlen, SQL_DRIVER_NOPROMPT);

Последнее что необходимо выполнить перед компиляцией — добавить odbc в качестве зависимости библиотеки:

Снимок экрана: добавление ODBC в качестве входной библиотеки.

Чтобы запустить приложение, откройте консоль Linux из меню Отладка:

Снимок экрана: пункт меню консоли Linux.

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

Снимок экрана окна консоли Linux.

Поздравляем! Вы успешно выполнили руководство и теперь можете подключиться к База данных SQL Azure из C++ на платформах Windows и Linux.

Получение полного решения C/C++ для этого руководства

На сайте GitHub можно найти решение, содержащее все примеры из этой статьи: GetStarted.