ORACLE sql大量数据导入小技巧

Q: ORACLE 导出的数据SQL 脚本带有shcema ,想导入另外一个schema 中。但文件太大, 文本编辑器打不开 ,怎办办。

A :

文件名为1.sql ,原来的schema 为Bob, 想导入Tom 下

sed -i 's/"Bob".//g' 1.sql

Q: sql 文件导出时没有批量提交语句。 想每1000往提交一次,避免最后因为机器休眠, 一条也没导入

A:

 awk '
{
    # 统计分号数量
    count = gsub(/;/, ";", $0)  # 计算当前行中的分号数量
    total += count              # 累计总分号数
    print $0                    # 输出当前行
​
    # 每1000个分号后添加 COMMIT;
    while (total >= 1000) {
        total -= 1000
        print "COMMIT;"
    }
​
}
' 1.sql > 2.sql
grep -n "COMMIT" 3.sql

Q: 如果sql 文件太大, sql 客户端打不开, 想拆分成几个文件

A:

 split -l 100000 3.sql 3_

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值