最近在使用SQLLDR解析上传的时候遇到问题-多个不同文件汇总到一个表中,其中有多个数据关联,要使用到自定义函数,且关联的多个字段计算后只保存结果,网上很多资料都没有找到合适的例子,相信很多童鞋有过类似的经历。自己摸索后特发一帖一解百优,希望对大家有帮助,上例子!
直接贴出这段生成的JAVA代码:
StringBuilder sb = new StringBuilder();
//从0行读取
sb.append("Options (Skip=0) \n");
sb.append("LOAD DATA\r\n ");
//设置数据库存储字符编码
sb.append("CHARACTERSET ZHS16GBK \r\n");
//读取映射文件路径及名称
sb.append("INFILE '"+ txtFilePath + "infos"+".dat' \r\n");
//这里是用APPEND 会直接插入到数据库中原先的数据不会动
sb.append("APPEND\r\n ");
数据库表名
sb.append("INTO TABLE p_table"+"\r\n ");
sb.append("TRAILING NULLCOLS\r\n ");
sb.append("(\r\n ");
//插入1表中的数据 此表使用sequences自动增长 使用自定义函数获得主键ID增长量,其实也可以直接写sequences常量
sb.append("ID \"getInfoseq()\",\r\n ");
//使用CONSTANT 直接插入传入过来的bizDate值,数据库直接保存bizDate
sb.append("BIZ_DATE CONSTANT '"+bizDate+"',\r\n ");
//POSITION是取文件中的字符166-173使用GBK的编码不需要考虑中文占位问题,如果是中文的话直接会按两位来读取,其余的编码可能需要转码
sb.append("col POSITION(166:173),\r\n ");
sb.append("time POSITION(157:164) \"to_date(:time,'yyyymmdd')\",\r\n ");
sb.append("A POSITION(73:87),\r\n ");
//这里自定义函数使用了A,T字段
sb.append("T POSITION(43:46) \"replacetrnc(:T,:A)\",\r\n ");
//插入3表中的数据 使用两个函数计算
sb.append("money POSITION(485:492) \"nvl(getmoney(:money),0)\",\r\n");
//插入4表中的数据
sb.append("CORT POSITION(890:894) \"getcort1(:CORT)\",\r\n ");
sb.append("COAM \"getCoam(nvl(getmoney(:FARE),0),getcort1(:CORT))\",\r\n ");
sb.append("CORT_2 POSITION(912:916) \"getcort2(:CORT_2)\",\r\n ");
//这里自定义函数需要注意,我需要的是money这个字段函数转后的值所以要嵌套函数转换
sb.append("COAM_2 POSITION(917:927) \"getCoam(nvl(getmoney(:money),0),getcort2(:CORT_2))\",\r\n ");
sb.append(") ");
分享也差不多,不知道大家有没明白,也就是存入数据的数据要使用to_Date to_number 等函数的时候,可以直接接在当前字段后面 并不需要先插入某个值后在转
例如数据的字段标示是 time :20121201 1-8位字符 但是我存入后的字段是DATE
可以直接这样写 date postion(1,8) "to_date(:date,'yyyymmdd')" 这里比原来的
time postion(1,8);
date "to_date(:date,'yyyymmdd')" ;
节省了一个字段,减少表空间冗余。
顺便分享下网上找来的资料
相关推荐
4. 使用转换函数:在某些情况下,可以在SQL*Loader控制文件中使用转换函数,如`CHARSET AD转化函数`,来转换数据的编码。例如: ``` LOAD DATA INFILE 'data.txt' INTO TABLE my_table ... FIELDS TERMINATED...
Oracle SQL*Loader(sqlldr)是Oracle数据库提供的一种强大的数据加载工具,用于将大量数据从文本文件快速导入到数据库表中。在这个实例中,我们将详细探讨如何使用SQL*Loader导入包含日期列的数据。 首先,我们...
SQL*Loader(简称sqlldr)是Oracle数据库系统中一个强大的数据加载工具,它可以从外部文件高效地批量导入数据到数据库中。这篇博文将详细介绍sqlldr的使用实例,帮助你理解和掌握这一工具,以便在实际工作中更有效地...
在标题提及的`sqlldr(linux+windows).rar`压缩包中,包含了适用于Linux和Windows操作系统的SQL*Loader工具,以及可能的使用案例和教程,使得用户无论在哪个操作系统环境下都能进行数据的快速上传。 **1. SQL*Loader...
SQL*Loader,简称sqlldr,是Oracle数据库系统中用于快速加载大量数据到数据库的一个实用工具。它是Oracle Data Pump的一部分,提供了高效的数据导入功能,适用于批量处理大数据量的场景。 1. **sqlldr简介** SQL*...
在这里,通过使用`to_date`函数将文本数据转换为日期类型,并指定了日期格式。这种方法适用于日期类型的字段,确保数据能正确导入。 4. **检查源文件:** 对于所有使用SQL*Loader的场景,都应该仔细检查源文件,...
裸设备是指直接由数据库管理系统(如Oracle)管理的存储空间,绕过了操作系统文件系统层,通常用于性能敏感的应用场景。 **5. 区分Oracle版本位数** 通过`$ sqlplus '/AS SYSDBA'`命令进入SQL*Plus环境,执行`...
1. **oci.dll**: Oracle Call Interface (OCI) 是Oracle数据库的主要应用程序编程接口(API),用于在C/C++等语言中与数据库进行交互。oci.dll是OCI的动态链接库,提供了一整套函数来执行SQL查询、事务处理、游标...
综上所述,Oracle外部表的使用涉及到元数据的定义、外部数据文件的格式和内容、以及数据迁移工具ORACLE_DATAPUMP和SQLLDR的配置与使用。在实际操作中,还需注意数据库版本间的兼容性问题,以及操作系统和Oracle...
例如,处理日期比较时,Greenplum推荐使用`date_trunc`函数;而处理复杂的查询和连接时,建议将多个SQL合并为一个,以减少I/O操作,提升性能。避免使用`EXISTS`和`NOT IN`语法,因为它们可能在分布式环境中导致不必...
- 使用DBCA工具进行创建,指定`OracleSID`。 - **Oracle目录结构**: - `Oracle_Base`:Oracle安装的基础目录。 - `Oracle_Home`:Oracle的具体安装路径。 - `Oracle_Home\bin`:包含Oracle的可执行文件,需要...
- Oracle支持使用`TRUNC`函数来截断数值,例如:`SELECT TRUNC(15.79, 1) FROM DUAL;`,这里返回的结果为15.7。 - SQL Server则提供了`ROUND`和`FLOOR`等函数来处理数值的截断或四舍五入操作。 #### 三、总结 ...
例如,可以指定使用或不使用特定的字段转换、记录过滤以及对特定字段应用SQL函数等。SQL*Loader还支持多种错误处理选项,这包括记录在装载过程中遇到的错误,并在装载后进行修正。 最后,文章中通过一个实例来说明...
Oracle数据库是由Oracle公司开发的一款关系型数据库管理系统,它以其强大的功能、高可用性和安全性而著称,在全球范围内被广泛应用于各种规模的企业和组织中,特别是在处理大规模数据和关键业务应用方面表现卓越。...
在Oracle学习笔记中,我们关注两个关键知识点:1) SQLLoader的使用和2) Oracle应用程序性能分析。 1. SQLLoader导入数据 SQLLoader是Oracle提供的一种高效的数据加载工具,能够将文本格式的数据批量导入到Oracle...
此外,SQL*Loader还允许在导入时对数据进行修改,如使用函数转换或赋值,例如: ```text LOAD DATA INFILE * INTO TABLE modified_data (rec_no "my_db_sequence.nextval", region "UPPER(:region)") ``` 这里,`...
Oracle提供了多种工具,如`expdp`和`impdp`用于数据泵导出和导入,以及`sqlldr`用于SQL*Loader的数据加载。 设置现实环境变量如ORACLE_HOME、PATH和TNS_ADMIN等,是确保Oracle客户端能够正确连接到服务器的关键步骤...