最近遇到一些开发知识小结

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 字符数组实现

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值