mysql 可扩展字段的表_不改表结构如何动态扩展字段

面对不断变化的需求,添加数据库字段可能导致锁表和性能问题。本文提出使用MySQL的JSON字段作为扩展字段,通过Java代码管理和存储动态数据,以此减少表结构修改。虽然在MySQL 5.7.8以下版本无法对JSON字段建立索引,但适合存储非热点数据,结合预留字段,提供了一种灵活的表结构解决方案。
摘要由CSDN通过智能技术生成

笔者的动态字段扩展解决方案主要针对 Mysql 5.7.8 以下版本,在 Mysql 5.7.8 已经新增 JSON Data Type,同样适用该方案,而且情况变得更加简单。

痛点

软件行业唯一不变的就是变化,比如功能上线之后,客户或 PM 需要对已有的功能增加一些合理的需求,完成这些工作必须通过添加字段解决,或者某些功能的实现需要通过增加字段来降低实现的复杂性等等。这些问题都会改动线上的数据库表结构,一旦改动就会导致锁表,会使所有的写入操作一直等待,直到表锁关闭,特别是对于数据量大的热点表,添加一个字段可能会因为锁表时间过长而导致部分请求超时,这可能会对企业间接造成经济上的损失。

解决方案

增加 json 格式的扩展字段。

下面配合一些代码来描述这个解决方案,读者便于去理解。

mysql 数据库脚本:

DROP TABLE IF EXISTS `cs_dustbin`;

CREATE TABLE IF NOT EXISTS `cs_dustbin` (

`id` VARCHAR(45) NOT NULL COMMENT '主键自增id',

`rfid_no` VARCHAR(20) NOT NULL COMMENT 'rfid 卡号',

`state` INT(1) NOT NULL COMMENT '垃圾桶状态:0:已注销;1:未使用;2:待使用;3:已使用(绑定收集点);',

`user_id` INT N

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值