独特的索引
到目前为止,我们可以在我们的表中创建由我们的唯一account_name
标识符索引的行,但是我们如何使用不同的primary_key
并确保它是唯一的?幸运的是,EOSIO的开发人员为我们提供了这项available_primary_key()
功能。
让我们首先创建一个struct来定义Item
我们的items
表。我们将使用uint64_t
类似法线来指定我们的主键id
。
// @abi table items i64
struct Item {
uint64_t id;
string name;
uint64_t attack;
account_name owner;
auto primary_key() const { return id; };
EOSLIB_SERIALIZE(Item, (id)(name)(attack));
};
typedef multi_index<N(items), Item> items_table;
现在让我们更新我们的操作以生成唯一的主键,而不是将它们作为参数。
void inventory::create(const account_name account, const string name, const uint64_t attack) {
items_table items(_self, _self);
items.emplace(account, account, [&](auto& item) {
item.id = items.available_primary_key();
item.name = name;
item.attack = attack;
item.owner = account;
});
}
我们已经从我们的actionvoid post(const account_name username, uint64_t index const string& msg_str)
删除了uint64_t index
,并且在创建新项目时我们已经用items.available_primary_key()
替换了index
来设置主键id
。