代码
@Service
public class SysNewsServiceImpl implements SysNewsService {
private Logger logger = LoggerFactory.getLogger(SysNewsServiceImpl.class);
@Autowired
private SysNewsMapper sysNewsMapper;
@Override
@Transactional(rollbackFor=Exception.class)
public void addSysNews(SysNews sysNews) {
SysNews sysNews1 = new SysNews( "2", "2", 2, 2, new Date());
SysNews sysNews2 = new SysNews( "东风然后涂华军软件园ada法师法师发大事发生", "1", 1, 1, new Date());
SysNews sysNews3 = new SysNews( "3", "3", 3, 3, new Date());
SysNews sysNews4 = new SysNews( "4", "4", 4, 4, new Date());
SysNews sysNews5 = new SysNews( "5", "5", 5, 5, new Date());
// 东风然后涂华军软件园ada法师法师发大事发生
List<SysNews> sysNewsList = new ArrayList<>();
sysNewsList.add(sysNews1);
sysNewsList.add(sysNews2);
sysNewsList.add(sysNews3);
sysNewsList.add(sysNews4);
sysNewsList.add(sysNews5);
for (SysNews news : sysNewsList) {
sysNewsMapper.insert(news);
}
}
}
Transactional注解的作用
如若在添加数据的过程中,中间有一个数据添加失败,那么之前添加到数据库中的数据全部回滚。后面的数据也不会添加到数据库中
保证数据安全
与try catch配合使用
@Service
public class SysNewsServiceImpl implements SysNewsService {
private Logger logger = LoggerFactory.getLogger(SysNewsServiceImpl.class);
@Autowired
private SysNewsMapper sysNewsMapper;
@Override
@Transactional(rollbackFor=Exception.class)
public void addSysNews(SysNews sysNews) {
SysNews sysNews1 = new SysNews( "2", "2", 2, 2, new Date());
SysNews sysNews2 = new SysNews( "东风然后涂华军软件园ada法师法师发大事发生", "1", 1, 1, new Date());
SysNews sysNews3 = new SysNews( "3", "3", 3, 3, new Date());
SysNews sysNews4 = new SysNews( "4", "4", 4, 4, new Date());
SysNews sysNews5 = new SysNews( "5", "5", 5, 5, new Date());
// 东风然后涂华军软件园ada法师法师发大事发生
List<SysNews> sysNewsList = new ArrayList<>();
sysNewsList.add(sysNews1);
sysNewsList.add(sysNews2);
sysNewsList.add(sysNews3);
sysNewsList.add(sysNews4);
sysNewsList.add(sysNews5);
for (SysNews news : sysNewsList) {
try {
sysNewsMapper.insert(news);
} catch (Exception e) {
logger.info("增加消息出错",e);
}
}
}
}
try catch注解的作用
如若在添加数据的过程中,中间有一个数据添加失败,那么catch的作用就是捕获该异常, 只让这一条数据不添加到数据库中。 后面的数据或者是这条数据之前的数据,依然可以添加到数据库中。
目的是不让业务中断 因为catch你已经捕获异常了,所以业务不会中断
而上面的没有加try catch的,因为出现了异常,没有捕获,业务也会随之中断