SQL Server Native Client ヘッダー ファイルとライブラリ ファイルの使用
SQL Server Native Client ヘッダー ファイルとライブラリ ファイルは、SQL Serverと共にインストールされます。 アプリケーションを開発するときは、開発に必要なすべてのファイルを開発環境にコピーしてインストールすることが重要です。 SQL Server Native Clientのインストールと再配布の詳細については、「SQL Server Native Clientのインストール」を参照してください。
SQL Server Native Client ヘッダー ファイルとライブラリ ファイルは、次の場所にインストールされます。
%PROGRAM FILES%\Microsoft SQL Server\110\SDK
SQL Server Native Client ヘッダー ファイル (sqlncli.h) を使用して、SQL Server Native Clientデータ アクセス機能をカスタム アプリケーションに追加できます。 SQL Server Native Client ヘッダー ファイルには、SQL Server 2005 で導入された新機能を活用するために必要なすべての定義、属性、プロパティ、およびインターフェイスが含まれています。
SQL Server Native Client ヘッダー ファイルに加えて、sqlncli11.lib ライブラリ ファイルもあります。これは、ODBC 用の一括コピー プログラム (BCP) 機能SQL Serverエクスポート ライブラリです。
SQL Server Native Client ヘッダー ファイルは、Microsoft Data Access Components (MDAC) で使用される sqloledb.h ヘッダー ファイルと odbcss.h ヘッダー ファイルの両方と下位互換性がありますが、SQLOLEDB の CLSID (MDAC に含まれるSQL Server OLE DB プロバイダー) や XML 機能のシンボル (サポート対象外) は含まれていませんSQL Server Native Client)。
ODBC アプリケーションは、同じプログラム内の SQL Server Native Client ヘッダー (sqlncli.h) と odbcss.h を参照できません。 SQL Server 2005 で導入された機能を使用していない場合でも、SQL Server Native Client ヘッダー ファイルは古い odbcss.h の代わりに機能します。
SQL Server Native Client OLE DB プロバイダーを使用する OLE DB アプリケーションは、sqlncli.h を参照するだけで済みます。 アプリケーションで MDAC (SQLOLEDB) と SQL Server Native Client OLE DB プロバイダーの両方を使用する場合は、sqloledb.h と sqlncli.h の両方を参照できますが、sqloledb.h への参照が先に来る必要があります。
SQL Server Native Client ヘッダー ファイルの使用
SQL Server Native Client ヘッダー ファイルを使用するには、C/C++ プログラミング コード内で include
ステートメントを使用する必要があります。 次のセクションでは、OLE DB と ODBC の両方のアプリケーションでこの操作を行う方法について説明します。
注意
SQL Server Native Client ヘッダー ファイルとライブラリ ファイルは、Visual Studio C++ 2002 以降を使用してのみコンパイルできます。
OLE DB
OLE DB アプリケーションで SQL Server Native Client ヘッダー ファイルを使用するには、次のプログラミング コード行を使用します。
#define _SQLNCLI_OLEDB_
include "sqlncli.h";
注意
アプリケーションで OLE DB と ODBC の両方の API を使用する場合は、上記の 1 行目のコードを省略する必要があります。 また、アプリケーションに sqloledb.h 用の include
ステートメントがある場合は、そのステートメントの後に sqlncli.h 用の include
ステートメントを指定する必要があります。
SQL Server Native Clientを使用してデータ ソースへの接続を作成する場合は、プロバイダー名の文字列として "SQLNCLI11" を使用します。
ODBC
ODBC アプリケーションで SQL Server Native Client ヘッダー ファイルを使用するには、次のプログラミング コード行を使用します。
#define _SQLNCLI_ODBC_
include "sqlncli.h";
注意
OLE DB API と ODBC API の両方がアプリケーションで使用されている場合は、上記のコードの最初の行を省略する必要があります。 また、アプリケーションに odbcss.h 用の #include
ステートメントがある場合は、そのステートメントを削除する必要があります。
SQL Server Native Clientを使用してデータ ソースへの接続を作成する場合は、ドライバー名の文字列として "SQL Server Native Client 11.0" を使用します。
各バージョンのコンポーネント名とプロパティ
プロパティ | SQL Server Native Client SQL Server 2005 |
SQL Server Native Client 10.0 SQL Server 2008 |
SQL Server Native Client 11.0 SQL Server 2014 |
MDAC |
---|---|---|---|---|
ODBC ドライバー名 | SQL Native Client (SQL Native Client) | SQL Server Native Client 10.0 | SQL Server Native Client 11.0 | SQL Server |
ODBC ヘッダー ファイル名 | Sqlncli.h | Sqlncli.h | Sqlncli.h | Odbcss.h |
ODBC ドライバー DLL | Sqlncli.dll | Sqlncl10.dll | Sqlncl11.dll | sqlsrv32.dll |
BCP API の ODBC lib ファイル | Sqlncli.lib | Sqlncli10.lib | Sqlncli11.lib | Odbcbcp.lib |
BCP API の ODBC DLL | Sqlncli.dll | Sqlncli10.dll | Sqlncli11.dll | Odbcbcp.dll |
OLE DB PROGID | SQLNCLI | SQLNCLI10 | SQLNCLI11 | SQLOLEDB |
OLE DB ヘッダー ファイル名 | Sqlncli.h | Sqlncli.h | Sqlncli.h | Sqloledb.h |
OLE DB プロバイダー DLL | Sqlncli.dll | Sqlncli10.dll | Sqlncli11.dll | Sqloledb.dll |
sqlncli.h では、SQLNCLI_VER マクロを使用して複数のバージョンのSQL Server Native Clientがサポートされています。 既定では、SQLNCLI_VERは既定で最新バージョンの SQL Server Native Client に設定されます。 sqlncli11.dll ではなく sqlncli10.dll を使用するアプリケーションをビルドするには、SQLNCLI_VER を 10 に設定します。
静的リンクと BCP 関数
BCP 関数を使用するアプリケーションでは、アプリケーションのコンパイルに使用されたヘッダー ファイルおよびライブラリに付属するのと同じバージョンのドライバーを接続文字列で指定することが重要です。
たとえば、SQL Server Native Client を使用してアプリケーションをコンパイルし、関連するライブラリ ファイル (sqlncli11.lib) とヘッダー ファイル (sqlncli.h) を \Program Files\Microsoft SQL Server\110\SDK からコンパイルする場合は、接続文字列に "DRIVER={SQL Server Native Client 11.0}" (ODBC を例として使用) を指定してください。
詳細については、「一括コピー操作の実行」を参照してください。