在新项目中,我们要求每一个写入数据库的操作不允许直接写入到MYSQL数据库中,防止在大并发情况下数据库的瓶颈出现,解决的思路是凡是有需要更新、插入数据库的需求,必须按规定封装成JSON数据,然后存放到REDIS的队列中,由数据库写入队列监控程序进行监视,发现后串行写入到数据库中。如果JAVA项目有在写入数据库的同时修改缓存的需要,那么自行修改缓存,数据库写入程序不负责修改缓存数据。
下面以一个有代表性的写入动作为例,进行说明:
学生表
CREATE TABLE `t_base_student` (
`ID`int(11) NOT NULL AUTO_INCREMENT COMMENT '学生表主键,自增长',
`STUDENT_GUID`char(36) DEFAULT NULL COMMENT '学生的GUID编号',
`STUDENT_NAME` varchar(20) DEFAULT NULL COMMENT '学生姓名',
`XB`char(2) DEFAULT NULL COMMENT '性别',
`BYXX` varchar(50) DEFAULT NULL COMMENT '毕业学校',
PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
插入一条测试数据
INSERT INTO `t_base_student` VALUES ('1', 'bd81eb89-b