在数据迁移中,经常会碰到null值的问题,比如在源库中,某些列可能是null值,但是在目标库中,却有非空约束。这样在数据的迁移过程中就会发生问题。
为了更好的对数据的非空问题进行判断,我写了如下的脚本来生成检查的脚本,基本的思路就是生成动态sql,类似 select count(1) from xxx where xxx is null,如果输出结果不为0,说明在源库中存在着非空约束的问题。
脚本需要在目标库中生成,然后在源库执行即可,可以在执行的过程中,考虑加入并行等。
因为非空约束的条件在user_constraints中式long类型卡所以不能做字符串拼接等操作,就当做独立的一列来处理。
sqlplus -s n1/n1 <<EOF
set linesize 150
set feedback off
set pages 0
col search_pre format a58
col search_condition format a50
spool not_null_constraint_$1.sql_tmp
select /*+rule*/
'select count(1) from ' || table_name || ' where ' search_pre,
search_condition, ';'
from user_constraints
where table_name =upper( '$1')
and constraint_type = 'C'
and constraint_name in
(select constraint_name
from user_cons_columns
where table_name = upper('$1')
and column_name in (select column_name
from user_tab_cols
where table_name =upper( '$1')
and nullable = 'N'));
spool off;
EOF
sed 's/ NOT / /g' not_null_constraint_$1.sql_tmp > not_null_constraint_$1.sql
rm not_null_constraint_$1.sql_tmp
exit
比如对于表T来说,object_id,object_name含有非空约束。
SQL> desc t
Name Null? Type
----------------------------------------- -------- ----------------------------
ID NUMBER
OBJECT_ID NOT NULL NUMBER
OBJECT_NAME NOT NULL VARCHAR2(30)
OBJECT_TYPE VARCHAR2(19)
CLOB_TEST CLOB
运行脚本后,生成的sql脚本内容如下所示,达到了预期的目标。
select count(1) from T where "OBJECT_NAME" IS NULL ;
select count(1) from T where "OBJECT_ID" IS NULL ;
数据迁移判断非空约束(r2笔记45天)
原创jeanron100 ©著作权
©著作权归作者所有:来自51CTO博客作者jeanron100的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
Java使用JsonNode判断实体类非空
使用jsonNode去判断实体类的参数是否为空
jsonnode java hutool