您的位置:首页 > 数据库 > Oracle

oracle导入大sql文件

2016-12-13 16:43 162 查看
公司经常要把数据导来导去的,不得不学习一下如何导入大文件的sql,好应对各种突发情况。

首先得会使用sqlplus连接远程数据库

sqlplus 用户名/密码@远程数据库ip:端口/实例名


连接成功之后使用命令

SQL>@E:\bigdata.sql


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

ERROR:
ORA-01756: quoted string not properly terminated


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

1.排查数据库服务器字符集:

select userenv('language') from dual;

---AMERICAN_AMERICA.AL32UTF8【此处的字符集是这个】


2.排查client字符集

在windows平台下,就是注册表里面相应OracleHome的NLS_LANG。还可以在dos窗口里面自己设置,

比如: set nls_lang=AMERICAN_AMERICA.ZHS16GBK


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

另外值得一提的是有些文件里面可能会出现一些空格之类的字符,到了sqlplus里面就会变成
 
,例如下面的等待输入,往往会影响导入的时间:

SQL>Enter value for nbsp;


所以需要在执行
SQL>@E:\bigdata.sql
时先设置一下关闭替代变量功能

set difine off


这样子就不会出现导入时等待的情况了,大大提高了导入文件的效率。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  oracle 数据库 sql