sqlite mysql 区块链_企业版区块链钱包开发之数据库选择及资金字段定义教程

很多开发钱包的开发者不知如何选择数据库,就这个问题笔者分享下个人心得。

很多开发钱包的开发者不知如何选择数据库,就这个问题笔者分享下个人心得。

# 开发企业版钱包时数据库如何进行选择?

我们在开发优盾钱包客户端初期,因为数据量小、用户少、管理地址少,且各个币种之间的资金差异问题,所以最初我们选择的是xml来存储资金信息,也解决了资金的多样性问题。

随着数据量的加大,慢慢的发现xml的弊端越来越明显,读取占用内存大,读取速度慢,易损坏等等。所以后面我们改为数据库存储模式。

数据库期间考虑的是中小型数据库,mysql、sqlite、access,mysql安装复杂,不能很好的集成到我们的客户端程序,access数据库达到50M左右的时候性能会急剧下降,记录数过多,一般记录数达到10万条左右的时候性能就也会急剧下降,sqlite相较于两者而言,即能免安装,性能也很好,所以最终选择的是sqlite。

sqlite有个致命缺点,就是同时只能有一个线程操作数据库写入,注意这里是同时写入操作,所以各位在这块要注意一些,以免后期在坑里爬不起来。

# 资金字段如何定义?

研究过区块链的小伙伴应该都知道不同币种的资金结构差异非常大,就ETH和BTC系列币来对比,ETH资金是纯粹的账户类型的,BTC资金则是未花类型的。

笔者研究了很多币种,现在市面上大部分的数字货币的资金结构都是这两种类型的,所以我们将资金结构定义成一种通用结构,address(地址),totalAmount(资金),frozenTotalAmount(冻结资金),frozen(是否冻结),nonce(ETH系列使用的nonce),utxo(BTC系列的未花集合,是未花转换得到的json串), utxo的结构(txid,indexNo,totalAmount,frozen),大家可以参照这个结构进行数据库资金表的字段定义。

附:

优盾钱包API接口官方文档:https://www.uduncloud.com/gateway-interface

很多开发钱包的开发者不知如何选择数据库,就这个问题笔者分享下个人心得。

开发企业版钱包时数据库如何进行选择?

我们在开发优盾钱包客户端初期,因为数据量小、用户少、管理地址少,且各个币种之间的资金差异问题,所以最初我们选择的是xml来存储资金信息,也解决了资金的多样性问题。

随着数据量的加大,慢慢的发现xml的弊端越来越明显,读取占用内存大,读取速度慢,易损坏等等。所以后面我们改为数据库存储模式。

数据库期间考虑的是中小型数据库,mysql、sqlite、access,mysql安装复杂,不能很好的集成到我们的客户端程序,access数据库达到50M左右的时候性能会急剧下降,记录数过多,一般记录数达到10万条左右的时候性能就也会急剧下降,sqlite相较于两者而言,即能免安装,性能也很好,所以最终选择的是sqlite。

sqlite有个致命缺点,就是同时只能有一个线程操作数据库写入,注意这里是同时写入操作,所以各位在这块要注意一些,以免后期在坑里爬不起来。

资金字段如何定义?

研究过区块链的小伙伴应该都知道不同币种的资金结构差异非常大,就ETH和BTC系列币来对比,ETH资金是纯粹的账户类型的,BTC资金则是未花类型的。

笔者研究了很多币种,现在市面上大部分的数字货币的资金结构都是这两种类型的,所以我们将资金结构定义成一种通用结构,address(地址),totalAmount(资金),frozenTotalAmount(冻结资金),frozen(是否冻结),nonce(ETH系列使用的nonce),utxo(BTC系列的未花集合,是未花转换得到的json串), utxo的结构(txid,indexNo,totalAmount,frozen),大家可以参照这个结构进行数据库资金表的字段定义。

附:

本文参与登链社区写作激励计划 ,好文好收益,欢迎正在阅读的你也加入。

发表于 2020-06-08 10:07

阅读 ( 319 )

学分 ( 0 )

分类:钱包

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值