oracle导入sql文件

公司以前都是用dmp操作数据导入导出,最近从别的地方人家给是sql文件数据库文件,不得不学习一下如何导入大文件的sql,好应对各种突发情况。
1、首先得会使用sqlplus连接远程数据库
sqlplus 用户名/密码@远程数据库ip:端口/实例名
2、连接成功之后使用命令

sql>@E:\areadata.sql;
sql>@/opt/oracle/area.sql;

有时候中文会出现乱码问题,或者报错。例如:

ERROR:
ORA-01756: quoted string not properly terminated

此时,需要排查数据库服务器的字符集和client的字符集
1.排查数据库服务器字符集:

sql>select userenv('language') from dual;
---AMERICAN_AMERICA.ZHS16GBK【此处的字符集是这个】

2.排查client字符集
在windows平台下,就是注册表里面相应OracleHome的NLS_LANG。还可以在dos窗口里面自己设置,比如:
set nls_lang=AMERICAN_AMERICA.ZHS16GBK

在linux下,修改bash_profile文件

$ vi .bash_profile
NLS_LANG='AMERICAN_AMERICA.ZHS16GBK'; export NLS_LANG

这个也可能跟sql文件有关,大家可以试试设置client字符集,多试两个应该就可以了。

另外有些文件里面可能会出现一些空格之类的字符,到了sqlplus里面就会变成 ,例如下面的等待输入,往往会影响导入的时间:
sql>Enter value for nbsp;

所以需要在执行sql>@E:\areadata.sql时先设置一下关闭替代变量功能
sql>set difine off;
这样子就不会出现导入时等待的情况了,大大提高了导入文件的效率。

转载于:https://blog.51cto.com/meiling/2130827

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值