Oracle迁移到SQLserver 空串(‘‘)和null 统一处理案

技术: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包

      <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-aop</artifactId>
          <version>5.3.7</version>
      </dependency>
    
    <!-- https://mvnrepository.com/artifact/org.aspectj/aspectjrt -->
	<dependency>
		<groupId>org.aspectj</groupId>
		<artifactId>aspectjrt</artifactId>
		<version>1.9.8.RC3</version>
	</dependency>

	<!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver -->
	<dependency>
		<groupId>org.aspectj</groupId>
		<artifactId>aspectjweaver</artifactId>
		<version>1.9.8.RC3</version>
	</dependency>

        b. spring 配置文件中开启AOP动态代理

        

<aop:aspectj-autoproxy></aop:aspectj-autoproxy>

        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;
				}
			}
 		}
     }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值