GridDB CクライアントはC言語用のインタフェースを提供します。
また、このリポジトリには簡単なサンプルプログラムがあります。
詳細はC APIリファレンスを参照してください。
以下の環境でCクライアントのビルドとサンプルプログラムの実行を確認しています。
OS: Ubuntu 22.04(x64) (gcc 11), Windows 11(x64) (VS2017), MacOS Catalina 12 (clang 13.1.6)
GridDB server: V5.7 CE(Community Edition), Ubuntu 22.04(x64)
OS: RockyLinux 9.4(x64) (gcc 11)
GridDB server: V5.7 CE(Community Edition), RockyLinux 9.4(x64)
$ cd client/c
$ ./bootstrap.sh
$ ./configure
$ make
を実行すると、binフォルダの下に以下のファイルやリンクが作成されます。
libgridstore.so
libgridstore.so.0
libgridstore.so.0.0.0
事前にGridDBサーバを起動しておく必要があります。
$ cp client/c/sample/sample1.c .
$ gcc -I./client/c/include -L./bin sample1.c -lgridstore
$ export LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:./bin
$ ./a.out <GridDB notification address(default is 239.0.0.1)> <GridDB notification port(default is 31999)>
<GridDB cluster name> <GridDB user> <GridDB password>
-->Person: name=name02 status=false count=2 lob=[65, 66, 67, 68, 69, 70, 71, 72, 73, 74]
(追加情報)
- client/c/includeフォルダの下に、ビルドに使われるgridstore.hファイルがあります。
- client/c/sampleフォルダの下に、サンプルプログラムがあります。
RPM/DEBパッケージ(https://github.com/griddb/c_client/releases) をダウンロードしてインストールしてください。
事前にGridDBサーバを起動しておく必要があります。
$ cp /usr/griddb_c_client-X.X.X/sample/sample1.c .
$ gcc sample1.c -lgridstore
$ ./a.out <GridDB notification address(default is 239.0.0.1)> <GridDB notification port(default is 31999)>
<GridDB cluster name> <GridDB user> <GridDB password>
-->Person: name=name02 status=false count=2 lob=[65, 66, 67, 68, 69, 70, 71, 72, 73, 74]
(追加情報)
- /usr/includeフォルダの下に、ビルドに使われるgridstore.hファイルがあります。
- /usr/lib64(CentOS)、/usr/lib/x86_64-linux-gnu(Ubuntu)フォルダの下に、ビルドおよび実行に使われるlibgridstore.soファイルがあります。
$ cd client/c
$ ./bootstrap.sh
$ ./configure
$ make
を実行すると、binフォルダの下に以下のファイルやリンクが作成されます。
libgridstore.dylib
libgridstore.0.dylib
libgridstore.0.0.0.dylib
事前にGridDBサーバを起動しておく必要があります。
$ cp client/c/sample/sample1.c .
$ gcc -I./client/c/include -L./bin sample1.c -lgridstore
$ export DYLD_LIBRARY_PATH=${DYLD_LIBRARY_PATH}:./bin
$ ./a.out <GridDB notification address(default is 239.0.0.1)> <GridDB notification port(default is 31999)>
<GridDB cluster name> <GridDB user> <GridDB password>
-->Person: name=name02 status=false count=2 lob=[65, 66, 67, 68, 69, 70, 71, 72, 73, 74]
(追加情報)
- client/c/includeフォルダの下に、ビルドに使われるgridstore.hファイルがあります。
- client/c/sampleフォルダの下に、サンプルプログラムがあります。
- <CMAKE_PATH>\bin\cmake-gui.exeをオープンします。
- "Where is the source code"に <C_CLIENT_SRC_PATH>\client\c\sample フォルダを指定します。
- "Where to build the binaries"にソリューションファイル(*.sln , *.vcxproj)の生成先フォルダを指定します。
- Configureボタンをクリック後、 "Specify the generator for this project"に"Visual Studio 15 2017 Win64"を指定します。
- Generateボタンをクリックするとファイルが生成されます。
ソリューションファイルの生成先フォルダのclient.slnファイルをクリックしてVSを起動後、clientソリューションをビルドしてください。
<C_CLIENT_SRC_PATH>\bin\x64\Releaseフォルダ(リリースモード時)、<C_CLIENT_SRC_PATH>\bin\x64\Debugフォルダ(デバッグモード時)の下に以下のファイルが作成されます。
gridstore_c.dll
gridstore_c.lib
事前にGridDBサーバを起動しておく必要があります。
ソリューションファイルの生成先フォルダのsample.slnファイルをクリックしてVSを起動後、sampleプロジェクトをビルドすると、<C_CLIENT_SRC_PATH>\bin\x64\Releaseフォルダ(リリースモード時)、<C_CLIENT_SRC_PATH>\bin\x64\Debugフォルダ(デバッグモード時)の下にsample.exeファイルが生成されます。
> sample.exe sample1 en <GridDB notification address(default is 239.0.0.1)> <GridDB notification port(default is 31999)>
<GridDB cluster name> <GridDB user> <GridDB password>
-->Person: name=name02 status=false count=2 lob=[65, 66, 67, 68, 69, 70, 71, 72, 73, 74]
(追加情報)
- client/c/includeフォルダの下に、ビルドに使われるgridstore.hファイルがあります。
- client/c/sampleフォルダの下に、サンプルプログラムがあります。
MSIパッケージ(https://github.com/griddb/c_client/releases) をダウンロードして実行してください。C:/Program Files/GridDB/GridDB C Client/X.X.Xフォルダの下にインストールされます。
以下は、VS2017の場合の手順です。
- x64のプロジェクトを作成。[構成マネージャ] - [アクティブソリューションプラットフォーム] - [新規作成]で "x64"を選択します。
- プロジェクトのソース ファイルにsample1.cファイルを追加します。
- Includeディレクトリの設定。[構成プロパティ] - [C/C++] - [全般] - [追加のインクルードディレクトリ]に gridstore.h が存在するディレクトリを指定します。
- インポートライブラリ(gridstore_c.lib)の設定。[リンカー] - [入力] - [追加の依存ファイル] に追加します。
- プロジェクトをビルドします。
事前にGridDBサーバを起動しておく必要があります。
> sample.exe <GridDB notification address(default is 239.0.0.1)> <GridDB notification port(default is 31999)>
<GridDB cluster name> <GridDB user> <GridDB password>
-->Person: name=name02 status=false count=2 lob=[65, 66, 67, 68, 69, 70, 71, 72, 73, 74]
詳細は以下のドキュメントを参照してください。
※Cクライアント(Community Edition)では空間型は利用できません。
- Issues
質問、不具合報告はissue機能をご利用ください。 - PullRequest
GridDB Contributor License Agreement(CLA_rev1.1.pdf)に同意して頂く必要があります。 PullRequest機能をご利用の場合はGridDB Contributor License Agreementに同意したものとみなします。
CクライアントのライセンスはApache License, version 2.0です。
サードパーティのソースとライセンスについては3rd_party/3rd_party.mdを参照ください。