Docs Menu
Docs Home
/ / /
C ドライバー
/ /

オブジェクト ID

項目一覧

  • 構成
  • オブジェクト ID のソート
  • オブジェクト ID の比較
  • 生成
  • ObjectId解析
  • オブジェクト ID のハッシュ
  • ObjectId作成時間の取得

libbson は、ObjectID を生成する簡単な方法を提供します。 要件に応じて、シングルスレッドまたはマルチスレッドで使用できます。

bson_oid_t 構造はObjectID MongoDB の を表します。これは96ビット識別子です。

  • 4バイト : ビッグエンディアン形式の UNIX タイムスタンプ。

  • 5バイト : ランダム数。

  • 3バイト : ビッグエンディアンのrand()から増加する24ビットの単調なカウンター。

C で並べ替える一般的な方法は、 qsort()を使用することです。 したがって、libson はqsort() bson_oid_comparent という名前の 互換コールバック関数を提供します 。2 つの bson_id_t less than 1の等価性に応じて、greater than 1 、 、または が返されます0 構造体。

2 つの bson_oid_t を比較するだけの場合 等価構造体には bson_oid_equal を使用します。

bson_id_t の生成 、以下を使用できます。

bson_oid_t oid;
bson_oid_init (&oid, NULL);

bson_id_t を含む string も解析できます 。入力stringの長さは 24 文字以上である必要があります。

bson_oid_t oid;
bson_oid_init_from_string (&oid, "123456789012345678901234");
bson_oid_t oid;
bson_oid_init_from_string_unsafe (&oid, "123456789012345678901234");

ハッシュテーブルに項目を保存する必要がある場合は、 bson_oid_t を キーとして使用します。libbson はこの目的のみでハッシュ関数を提供します。 JB ハッシュに基づいています。

unsigned hash;
hash = bson_oid_hash (oid);

bson_oid_t が は bson_oid_get_time_t を使用して生成されました。

time_t t;
t = bson_oid_get_time_t (oid);
printf ("The OID was generated at %u\n", (unsigned) t);

戻る

Handling Errors