欢迎回到高级EOS开发系列,在这里我将讨论教程或课程很少涉及的高级技术和功能。本系列的目的是汇集您在EOS网络上作为分布式应用程序开发人员完成技能所需的缺失部分。每个帖子都是按难度排序的,所以如果您想要概述,我建议您从第1部分开始,逐步完成。这些示例的完整代码可以在GitHub上找到。
MitchPierias/Advanced-EOS-Examples
由于这些是高级或扩展的主题,我很严肃地假设您已经了解基础知识,并希望进一步了解您的知识。出于这个原因,这些文章中共享的代码将只是为了讨论的目的而简明扼要。
这篇文章相对较短,但涵盖了多索引表,唯一主索引的基本且看似未被发现的方法。
独特的索引
到目前为止,我们可以在我们的表中创建由我们的唯一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;
您会注意到这与我们在Advanced EOS系列中使用的表结构相同- 第3部分 - 辅助索引。现在让我们更新我们的操作以生成唯一的主键,而不是将它们作为参数。
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
。