博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EOSIO MySQL 插件 issue 2
阅读量:6544 次
发布时间:2019-06-24

本文共 1763 字,大约阅读时间需要 5 分钟。

文/温国兵

这是「区块链技术指北」的第 41 篇文章。

如果对我感兴趣,想和我交流,我的微信号:Wentasy,加我时简单介绍下自己,并注明来自「区块链技术指北」,同时我会把你拉入微信群。

题图来自: © ChainONE / Original /

0x00 背景


链上数据如何转化为 API 友好的数据,这是一个很重要的话题。因为能够转化为 API 友好的数据,对于开发者而言,可以极大地提高效率。目前 EOS 生态有很多插件,比如 MySQL 插件、ES 插件、Kafka 插件等等。

笔者在测试环境部署了基于 写的 MySQL 插件,结果同步数据时发现有如下的异常。上文提到了 amount 字段过短,来看看本文是什么问题吧。

0x01 解决


查看 nodeos 日志,可以发现如下异常。

terminate called after throwing an instance of 'soci::mysql_soci_error'  what():  Data too long for column 'public_key' at row 1 while executing "INSERT INTO accounts_keys(account, public_key, permission) VALUES (:ac, :ke, :pe) " with :ac="walletiphone", :ke="PUB_R1_81x8BXgDQGTWmcAaavfCDcVTTyzz1BeBYbje9yJomVMCJZbz86", :pe="owner".复制代码

我们查看表结构,可以得知 public_key 长度为 53。

[root@localhost][eos]> DESC accounts_keys;+------------+-------------+------+-----+---------+-------+| Field      | Type        | Null | Key | Default | Extra |+------------+-------------+------+-----+---------+-------+| account    | varchar(12) | YES  | MUL | NULL    |       || public_key | varchar(53) | YES  |     | NULL    |       || permission | varchar(12) | YES  |     | NULL    |       |+------------+-------------+------+-----+---------+-------+3 rows in set (0.00 sec)复制代码

我们尝试将 public_key 改为 64,重新同步解决。

ALTER TABLE accounts_keys CHANGE COLUMN public_key public_key varchar(64) DEFAULT NULL;复制代码

0x02 小结


MySQL 插件目前不太成熟,还有很多坑,谨慎入坑。

「区块链技术指北」同名 知识星球,二维码如下,欢迎加入。

「区块链技术指北」相关资讯渠道:

  • 「区块链技术指北」同名知识星球,
  • 官网,
  • 官方博客,
  • 官方社区,
  • Telegram Channel,
  • Telegram Group,
  • Twitter,
  • Facebook,
  • 新浪微博,

同时,本系列文章会在以下渠道同步更新,欢迎关注:

  • 「区块链技术指北」同名微信公众号(微信号:BlockchainAge)
  • 个人博客,
  • 知乎,
  • 简书,
  • Steemit,
  • Medium,
  • 掘金,
  • EOS LIVE,
  • 币乎,

原创不易,读者可以通过如下途径打赏,虚拟货币、美元、法币均支持。

  • BTC: 3QboL2k5HfKjKDrEYtQAKubWCjx9CX7i8f
  • ERC20 Token: 0x8907B2ed72A1E2D283c04613536Fac4270C9F0b3
  • PayPal:
  • 微信打赏二维码

–EOF–

版权声明:

转载地址:http://ezldo.baihongyu.com/

你可能感兴趣的文章
《高性能mysql》到手
查看>>
(转)关于如何学好游戏3D引擎编程的一些经验
查看>>
使用Kotlin为你的APP自定义一个统一的标题栏
查看>>
EF各版本增删查改及执行Sql语句
查看>>
拓扑排序
查看>>
jQGrid API
查看>>
Bzoj1758: [Wc2010]重建计划
查看>>
redis集群部署及踩过的坑
查看>>
j2EE监听器-listener
查看>>
使用pip命令报You are using pip version 9.0.3, however version 18.0 is available pip版本过期.解决方案...
查看>>
(转)LINQ之路
查看>>
Django REST框架--关系和超链接api
查看>>
双击防止网页放大缩小HTML5
查看>>
C#的一些学习方法
查看>>
U3D Invoke() IsInvoking CancelInvoke方法的调用
查看>>
Javascript 如何生成Less和Js的Source map
查看>>
中间有文字的分割线效果
查看>>
<悟道一位IT高管20年的职场心经>笔记
查看>>
volatile和synchronized的区别
查看>>
10.30T2 二分+前缀和(后缀和)
查看>>