5.2 使用文件 ID

本節說明什麼是文件 ID 以及如何使用它。

每個文件都有一個唯一識別碼,稱為文件 ID,可以將其視為相當於表格的主鍵。文件 ID 值通常在新增文件時由伺服器自動產生,但也可以手動指派。指派的文件 ID 會在 collection.add() 操作的 Result(Connector/J 的 AddResult)物件的 generatedIds 屬性中傳回,並且可以使用 getGeneratedIds() 方法存取。如需文件 ID 的更多背景資訊,請參閱第 5.3 節「瞭解文件 ID」

以下 JavaScript 程式碼範例顯示如何將文件新增至集合、擷取新增文件的 ID,並測試是否無法新增重複的 ID。

mysql-js > var result = mycollection.add({test:'demo01'}).execute()
mysql-js > print(result.generatedIds)
[
    "00006075f6810000000000000006"
]
mysql-js > var result = mycollection.add({test:'demo02'}).add({test:'demo03'}).execute()
mysql-js > print(result.generatedIds)
[
    "00006075f6810000000000000007",
    "00006075f6810000000000000008"
]

mysql-js > mycollection.find()
{
    "_id": "00006075f6810000000000000006",
    "test": "demo01"
}
{
    "_id": "00006075f6810000000000000007",
    "test": "demo02"
}
{
    "_id": "00006075f6810000000000000008",
    "test": "demo03"
}
3 documents in set (0.0102 sec)
mysql-js > var result = mycollection.add({_id:'00006075f6810000000000000008', test:'demo04'}).execute()
Document contains a field value that is not unique but required to be (MySQL Error 5116)

如以上範例所示,文件 ID 儲存在文件的 _id 欄位中。文件 ID 是長度上限為 32 個字元的 VARBINARY()。如果在建立文件時提供了 _id,則會採用;如果沒有提供 _id,則會自動指派給文件。

以下範例說明如何提供或自動產生 _id 值。假設 test 結構描述存在並已指派給變數 db,並且存在集合 my_collection,而且 custom_id 是唯一的。

// If the _id is provided, it will be honored
var result = myColl.add( { _id: 'custom_id', a : 1 } ).execute();
var document = myColl.find("a = 1").execute().fetchOne();
print("User Provided Id:", document._id);

// If the _id is not provided, one will be automatically assigned
result = myColl.add( { b: 2 } ).execute();
print("Autogenerated Id:", result.getGeneratedIds()[0]);

有些文件具有自然唯一索引鍵。例如,包含書籍清單的集合很可能會在每個代表書籍的文件中包含國際標準書號 (ISBN)。ISBN 是長度為 13 個字元的字串,這完全在 _id 欄位的 32 個字元長度限制內。

// using a book's unique ISBN as the object ID
myColl.add( {
_id: "978-1449374020",
title: "MySQL Cookbook: Solutions for Database Developers and Administrators"
}).execute();

使用 find(),依文件 ID 從集合中擷取新插入的書籍。

var book = myColl.find('_id = "978-1449374020"').execute();

目前,X DevAPI 不支援使用隱含的 _id 以外的任何文件欄位作為文件 ID—沒有辦法定義另一個索引鍵來執行相同的功能。