高级EOS系列 - 第4部分 - 表的唯一性


欢迎回到高级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

原文链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值