行使SQL有用地插入大量数据
发布时间:2021-04-03 03:35:23 所属栏目:编程 来源:网络整理
导读:嗨我经常需要在表格中插入大量数据.例如,我将以excel或文本文件的形式提供数据 1,a3,bsdf4,sdkfj5,something129,else 然后我经常在这个例子中构造6个插入语句并运行SQL脚本.当我必须向服务器发送数千个小包时,我发现这很慢,这也会给网络带来额外的开销. 你最
|
嗨我经常需要在表格中插入大量数据.例如,我将以excel或文本文件的形式提供数据 1,a 3,bsdf 4,sdkfj 5,something 129,else 然后我经常在这个例子中构造6个插入语句并运行SQL脚本.当我必须向服务器发送数千个小包时,我发现这很慢,这也会给网络带来额外的开销. 你最好的方法是什么? 更新:我正在使用ORACLE 10g. 解决方法使用 Oracle external tables.另见例如 > OraFaq about external tables 一个简单的例子,应该让你开始 您需要一个位于服务器目录中的文件(熟悉directory objects): SQL> select directory_path from all_directories where directory_name = 'JTEST'; DIRECTORY_PATH -------------------------------------------------------------------------------- c:datajtest SQL> !cat ~/.gvfs/jtest on 192.168.xxx.xxx/exttable-1.csv 1,else 创建外部表: create table so13t (
id number(4),data varchar2(20)
)
organization external (
type oracle_loader
default directory jtest /* jtest is an existing directory object */
access parameters (
records delimited by newline
fields terminated by ','
missing field values are null
)
location ('exttable-1.csv') /* the file located in jtest directory */
)
reject limit unlimited;
现在,您可以使用SQL的所有功能来访问数据: SQL> select * from so13t order by data;
ID DATA
---------- ------------------------------------------------------------
1 a
3 bsdf
129 else
4 sdkfj
5 something (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐
热点阅读


