DBOPEN(3) FreeBSD ライブラリ関数マニュアル DBOPEN(3)
名称
dbopen − データベースアクセス方式 |
書式
#include <sys/types.h> DB * |
dbopen(const char *file, int flags, int mode, DBTYPE type, const void *openinfo); |
解説 |
dbopen() は、データベースファイルへのライブラリインタフェースです。サポー トされているファイルフォーマットは、 btree 形式、ハッシュ形式、UNIX ファ イル指向形式です。 btree フォーマットは、ソート済みのバランスのとれたツ リー構造の表現です。ハッシュフォーマットは、拡張可能で動的なハッシュス キーマです。フラットファイルフォーマットは、固定長または可変長レコードか らなるバイトストリームファイルです。フォーマットおよびファイルフォーマッ トに固有の情報については、それぞれのマニュアルページに詳しく述べられてい ます。 btree(3), hash(3), recno(3) です。 dbopen() は、読み込みまたは書き込み用に file をオープンします。ディスク上 に保持する必要のないファイルは、ファイルパラメータを NULL に設定すること で作成できます。 引数 flags と引数 mode は、 open(2) で指定されものと同じです。しかし、 O_CREAT, O_EXCL, O_EXLOCK, O_NONBLOCK, O_RDONLY, O_RDWR, O_SHLOCK, O_TRUNC の各フラグだけに意味があります (データベースファイルは O_WRONLY ではオープンできないことに注意してください)。 引数 type は、タイプ DBTYPE (インクルードファイル 〈db.h〉 で定義されていま す) であり、 DB_BTREE, DB_HASH, DB_RECNO を設定できます。 引数 openinfo は、アクセス方式のマニュアルページに説明してあるように、ア クセス方式に固有の構造を指すポインタです。 openinfo が NULL の場合、各ア クセス方式は、システムとアクセス方式に適切なデフォルトを使用します。 dbopen() は、処理が成功すると DB 構造体を指すポインタを返し、エラーの場合 にはヌルを返します。 DB 構造体は、インクルードファイル 〈db.h〉 内に定義さ れており、少なくとも次のフィールドが含まれています。 typedef struct { |
DBTYPE type; |
||
int (*close)(const DB *db); |
||
int (*del)(const DB *db, const DBT *key, u_int flags); |
||
int (*fd)(const DB *db); |
||
int (*get)(const DB *db, DBT *key, DBT *data, u_int flags); |
||
int (*put)(const DB *db, DBT *key, const DBT *data, |
||
u_int flags); |
||
int (*sync)(const DB *db, u_int flags); |
||
int (*seq)(const DB *db, DBT *key, DBT *data, u_int flags); |
} DB; これらの要素は、データベースタイプと各種のアクションを実行する関数のセッ トを記述しています。これらの関数は、 dbopen() によって返された構造体への ポインタを引数に取り、時々キー / データ構造とフラグ値を指す 1 つまたは複 数のポインタを取ることもあります。 |
type
基本アクセス方式 (およびファイルフォーマット) のタイプ。 close del パラメータ flags は次の値に設定できます。 R_CURSOR delete ルーチンはエラー終了時には -1 を返し ( errno を設定)、正常 終了時には 0 を返します。指定した key がファイルの中になかった場 合は 1 を返します。 fd get put パラメータ flags には次の値の 1 つを設定できます。 R_CURSOR R_IAFTER R_IBEFORE R_NOOVERWRITE R_SETCURSOR R_SETCURSOR が利用できるのは、 DB_BTREE と DB_RECNO のアクセス方 式でだけです。キーには、変化しない固有の順序があることを意味して いるからです。 R_IAFTER と R_IBEFORE は DB_RECNO アクセス方式にだけ利用できま す。どれも、アクセス方式が新しいキーを作成できることを意味してい るからです。これは、キーが順序付けられており独立な場合にだけ真と なります。たとえば、レコード番号です。 put ルーチンのデフォルトの動作は、新しいキー/データの組を入力し、 それ以前に存在していたキーを置き換えることです。 put ルーチンはエラー終了時には -1 を返し ( errno を設定)、正常終 了時には 0 を返し、 R_NOOVERWRITE フラグが設定されていて、しかも キーがファイル内に既に存在する場合は 1 を返します。 seq シーケンシャルなキー / データの組の取り出しは、いつでも開始するこ とができ、 ‘‘カーソル’’ の位置は del, get, put, sync の各ルーチン による呼び出しによって影響を受けません。シーケンシャルな走査の間 のデータベースの修正は走査に反映されます。すなわち、カーソルの前 に挿入されたレコードが返されるまでの間、カーソルの後ろに挿入され たレコードは返されません。 flags 値は次の値の 1 つにセットしなければ なりません。 R_CURSOR R_FIRST R_LAST R_NEXT R_PREV R_LAST と R_PREV が利用できるのは、 DB_BTREE と DB_RECNO の各アク セス方式についてだけです。これらはそれぞれキーに変化しない固有の 順序があることを意味しているからです。 seq ルーチンはエラー終了時には -1 を返し ( errno を設定)、正常終 了時には 0 を返し、指定のキーまたは現在のキーより小さいかまたは大 きいキー / データの組が存在しない場合は 1 を返します。 DB_RECNO アクセス方式が使用されていて、しかもデータベースファイルがキャラ クタ特殊ファイルであり、完全なキー / データの組がその時点で存在し ない場合、 seq ルーチンは 2 を返します。 sync flags 値は次の値にセットできます。 R_RECNOSYNC sync ルーチンはエラー終了時には -1 を返し ( errno を設定)、正常終 了時には 0 を返します。 キー / データの組 |
すべてのファイルタイプへのアクセスはキー / データの組を基にしています。 キーとデータの両方が次のデータ構造で表されます。 typedef struct { |
void *data; |
||
size_t size; |
} DBT; DBT 構造体の要素は次のように定義されます。 |
data
バイトストリングを指すポインタ。 size キーとデータバイトストリングは、同時に利用できるメモリにフィットする必要 はありますが、参照できる文字列の長さには本質的には制限がありません。アク セス方式は、バイトストリングのバイトアラインについては何の保証もしていな いことに注意すべきです。 エラー |
dbopen() ルーチンがエラー終了すると、ライブラリルーチン open(2) や malloc(3) で書かれているエラー、または下記のエラーに対する errno をセット します。 |
[EFTYPE]
ファイルのフォーマットが間違っています。 [EINVAL] close ルーチンがエラー終了すると、ライブラリルーチン close(2), read(2), write(2), free(3), fsync(2) に書かれているエラーについての errno をセット します。 del, get, put, seq の各ルーチンがエラー終了すると、ライブラリルーチン read(2), write(2), free(3), malloc(3) に書かれているエラーについての errno をセットします。 fd ルーチンは、メモリ内のデータベースでエラー終了すると、 ENOENT に errno をセットします。 sync ルーチンがエラー終了すると、ライブラリルーチン fsync(2) に書かれてい るエラーについての errno をセットします。 関連項目 |
Margo Seltzer and Michael Olson, LIBTP: Portable, ModularTransactions for UNIX, USENIX proceedings, Winter 1992.
バグ
typedef DBTs は、 ‘‘data base thang’’ の略称で、まだ使用されていない合理 的な名前を誰も思いつかなかったために使われることになりました。 ファイル記述子インタフェースは構成が調和しておらず、インタフェースの今後 のバージョンでは削除される予定です。 どのアクセス方式も、並行アクセス、ロック、またはトランザクションは、どの ような形式でも提供しません。 FreeBSD 10.0 January 2, 1994 FreeBSD 10.0 |