Python Hash分表

 

1. 创建数据表(10张分表为例)

创建 10 张分表:eth_special_addr_trx_0, eth_special_addr_trx_1, ......, eth_special_addr_trx_9

    # 创建 10 个Hash分表
    for i in range(10):
        sql_create_table = '''
            create table eth_special_addr_trx_{}
            (
              tx_hash      varchar(70) primary key not null
              comment '交易hash值',
              block        varchar(15) null
              comment '所在区块',
              create_time  varchar(25) null
              comment '交易创建时间',
              constraint ethereum_special_address_transactions_{}_tx_hash_uindex
              unique (tx_hash)
            )
              comment 'ETH 交易表';
            '''.format(i, i)
        cursor.execute(sql_create_table)
        mysql_conn.commit()

 

2.数据入库

根据 address 值唯一确定一个hashID, hashID即代表哪一个分表。

...

def hashID(address, max_num):
    """根据 address 确定唯一 hash 值(确定分表)"""
    hash_str = hashlib.md5(address.encode(encoding='UTF-8')).hexdigest()   # 16进制 -- 900150983cd24fb0d6963f7d28e17f72
    num = int(hash_str[:2] + hash_str[-2:], 16)  # 16进制 --> 10进制
    print(hash_str, hash_str[:2], hash_str[-2:], num)
    hashID = num % max_num  # 8
    print('HashID:', hashID)
    return hashID

# 调用 hashID, 确定 分表id
table_id = hashID(address, 10)

# mysql操作,保存入库
insert_sql = '''insert into eth_special_addr_trx_{} (`tx_hash`,`block`,`create_time`) value(%s, %s, %s)'''.format(table_id)
data = (tx['tx_hash'], tx['block'], tx['create_time'])
cursor.execute(insert_sql, data)
mysql_conn.commit()

...

 

 

-------- END --------

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值