技术:spring,spring JdbcTemplate
背景:数据库由oracle迁移到sqlserver
问题:数据库由oracle迁移到了sqlserver ,由于oracle 空串('')和null 在入库之后都会转为[NULL](oracle中的null),然后sqlserver 空串('')和null在入库之后分别是 空串('') he [NULL],这样就会导致,在Oracle和sqlserver中查出来的数据不一致,为了解决这个问题,提出以下几个案:
1.各个处理,即就是在每个insert/update 处判断 如果是 "" 就直接转化为null,这样就保证了入库一致,但是问题是,可能会漏,处理地方太多,不适合
2.使用AOP 监控JdbcTemplate 的update(JdbcTemplate 不管是insert还是update 还是delete 都是 使用的update),不说了,直接撸代码
a. pom 中引入以下AOP包
org.springframework spring-aop5.3.7 org.aspectj aspectjrt1.9.8.RC3 org.aspectj aspectjweaver1.9.8.RC3
b. spring 配置文件中开启AOP动态代理
c.代码跟上
@Component @Aspect public class JdbcAspect { @Pointcut("execution(* org.springframework.jdbc.core.JdbcTemplate.update(..))") public void methodPointCut(){ } @Before("methodPointCut()") public void beforeMethod(JoinPoint point){ if(null != point.getArgs() && point.getArgs().length > 0) { Object[] argsParames = (Object[]) point.getArgs()[1]; Object argsParame = null; for (int i = 0; i < argsParames.length; i++) { argsParame = argsParames[i]; if(null != argsParame && "".equals(argsParame)) { argsParames[i] = null; } } } } }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)