1.Mysql数据库联合主键设置(id,policy_id)
CREATE TABLE `enterprise_policy` (
`id` bigint(20) NOT NULL,
`policy_id` varchar(20) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '政策id',
`enterprise_code` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '企业代码',
`application_time` datetime DEFAULT NULL COMMENT '申报日期',
`application_result` int(1) DEFAULT NULL COMMENT '申报结果',
`application_by` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '申报人',
PRIMARY KEY (`id`,`policy_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
2.ENGINE=InnoDB,myisam
myisam:读取速度快,支持锁全表的所以插入更新速度慢,这样的话大量并发操作时需要等待的时间变长,不支持事务。不支持外键。
InnoDB:支持锁行,支持事务,支持外键。不保存表的具体行数(select count(*) 慢一点)
3.Transactional 回滚失效
@PostMapping("/****XX")
@ResponseBody
@Transactional(rollbackFor = { Exception.class })
public ResponseResult enterprinsePolicyInfo(EnterpriseInfoDto enterpriseInfoDto){
ModelMapper modelMapper = new ModelMapper();
EnterpriseInfo enterpriseInfo = modelMapper.map(enterpriseInfoDto, EnterpriseInfo.class);
EnterprisePolicy enterprisePolicy = modelMapper.map(enterpriseInfoDto, EnterprisePolicy.class);
if(StringUtil.isBlank(enterprisePolicy.getPolicyId()) ){
return fail(false,"政策Id为空!");
}
try{
enterpriseInfoService.deleteById(enterpriseInfo.getId());
enterpriseInfoService.insert(enterpriseInfo);
Integer rs=enterprisePolicyService.selectEnterprisePolicyById(enterprisePolicy.getId(),enterprisePolicy.getPolicyId());
if(rs>0){
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
return fail(false,"申报政策重复!");
}
enterprisePolicyService.insert(enterprisePolicy);
return success(true,"新增成功!");
}catch (Exception e){
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
return fail(false,"新增失败!");
}
}
以上代码是我写的一个简单的Api新增方法,当我只加了注解@Transactional不加(TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();)手动设置
或抛出异常 回滚会失败,因为try-catch 捕获异常你不抛出或不手动回滚 ,事务是会失效的,至于为什么请自行百度。
因为我还需要在catch中return 所以只能手动设置回滚。
当然事务失败的另一种原因可能是你的表没有设置为:InnoDB
4.String,CharSequence ,StringBuffere,StringBuilder
String不可变:底层final char
CharSequence:字符序列,string 实现了charsequence
StringBuffer:可变字符串 线性安全的
StringBuilder:可变字符串 线性不安全
StringBuffer和StringBuilder都它们都继承于AbstractStringBuilder,实现了CharSequence接口
String,StringBUffer,StringBuilder 字符数组实现