mysql 5亿数据 查询_MySQL 亿级数据数据库优化方案测试-银行交易流水记录的查询...

原标题:MySQL 亿级数据数据库优化方案测试-银行交易流水记录的查询

作者:逸宸a

链接:https://www.jianshu.com/p/cbdef47fb837

对MySQL的性能和亿级数据的处理方法思考,以及分库分表到底该如何做,在什么场景比较合适?

比如银行交易流水记录的查询

限盐少许,上实际实验过程,以下是在实验的过程中做一些操作,以及踩过的一些坑,我觉得坑对于读者来讲是非常有用的。

首先:建立一个现金流量表,交易历史是各个金融体系下使用率最高,历史存留数据量最大的数据类型。现金流量表的数据搜索,可以根据时间范围,和个人,以及金额进行搜索。

-- 建立一张 现金流量表

DROPTABLEIFEXISTS`yun_cashflow`;

CREATETABLE`yun_cashflow`(

`id`bigint(20) NOTNULLAUTO_INCREMENT,

`userid`int(11) DEFAULTNULL,

`type`int(11) DEFAULTNULLCOMMENT'1、入账,2提现',

`operatoruserid`int(11) DEFAULTNULLCOMMENT'操作员ID',

`withdrawdepositid`bigint(20) DEFAULTNULLCOMMENT'提现ID',

`money`doubleDEFAULTNULLCOMMENT'钱数',

`runid`bigint(20) DEFAULTNULLCOMMENT'工单ID',

`createtime`timestampNULLDEFAULTCURRENT_TIMESTAMPONUPDATECURRENT_TIMESTAMP,

PRIMARY KEY(`id`)

) ENGINE=InnoDBAUTO_INCREMENT=63DEFAULTCHARSET=utf8;

然后开始造1个亿的数据进去。

-- 循环插入

dropPROCEDUREtest_insert;

DELIMITER;;

CREATEPROCEDUREtest_insert()

begin

declarenumint;

setnum=0;

while num < 10000 do

insertintoyun_cashflow(userid,type,operatoruserid,withdrawdepositid,money) values(FLOOR(7+ (RAND() * 6))+FLOOR(22+ (RAND() * 9)),1,FLOOR(97+ (RAND()

* 6))+FLOOR(2+ (RAND() * 9)),FLOOR(17+ (RAND() * 6))+FLOOR(2+ (RAND() * 9)),FLOOR(5+ (RAND() * 6))+FLOOR(2+ (RAND() * 9)));

setnum=num+1;

endwhile;

END;;

calltest_insert();

坑一:

这个存储过程建立好了之后,发现插入数据特别的慢,一天一晚上也插入不到100万条数据,平均每秒40~60条数据,中间我停过几次,以为是随机函数的问题,都变成常数,但效果一样,还是很慢,当时让我对这个MySQL数据库感觉到悲

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值