oracle sqlldr decode,sqlldr时遇到的一个问题
数据格式:
20091231 !445381003 !01 !10000463772321 !S0100103 !156 !101 !0
!0.00 !0.00 !0 !1 !110.00 !44 !20091231 !
加载ctl:
load data
infile
'/opt/TestData/psbc/data/TestData/T98_INDPTY_TX_STAT.txt'
append into table T98_INDPTY_TX_STAT
fields terminated by "!"
#########fields terminated by whitespace##以空格分隔
(SUMM_DATE,STAT_ORG_ID,BIZ_TYPE_CD,CONFORM_INDPARTY_ID,PRODUCT_ID,CURRENCY_CD,TX_TYPE_CD,MON_ACCUM_TX_NUM,MON_ACCUM_TX_AMT,QUA_ACCUM_TX_AMT,QUA_ACCUM_TX_NUM,YR_ACCUM_TX_NUM,YR_ACCUM_TX_AMT,PROVINCE_CD,TXDATE,BLANK)
加载出错:找不到列BLANK,删掉BLANK,因为数据文件中没有该列内容。
改正后,再加载发现还是出错:
原因是date格式不能直接load,指定下,加date ‘yyyymmdd hh24:mi:ss’
再加载,还报错,发现分隔符处有空格,"!"改为" !"
再加载,OK
若要加载固定格式数据,则要在列后面指定类型,如date
最终ctl脚本为
load data
infile
'/opt/TestData/psbc/data/TestData/T98_INDPTY_TX_STAT.txt'
append into table T98_INDPTY_TX_STAT
fields terminated by " !"
(SUMM_DATE date 'yyyymmdd hh24:mi:ss',STAT_ORG_ID
char(9),BIZ_TYPE_CD,CONFORM_INDPARTY_ID,PRODUCT_ID,CURRENCY_CD,TX_TYPE_CD,MON_ACCUM_TX_NUM,MON_ACCUM_TX_AMT,QUA_ACCUM_TX_AMT,QUA_ACCUM_TX_NUM,YR_ACCUM_TX_NUM,YR_ACCUM_TX_AMT,PROVINCE_CD,TXDATE
date 'yyyymmdd hh24:mi:ss')
并行加载
sqlldr psbc/psbc control=/opt/impora/t1.ctl parallel=true
&
sqlldr psbc/psbc control=/opt/impora/t2.ctl parallel=true
&
sqlldr psbc/psbc control=/opt/impora/t3.ctl parallel=true
&
sqlldr psbc/psbc control=/opt/impora/t4.ctl parallel=true
&
并行加载还是很慢
直接灌入磁盘,加入direct参数
sqlldr psbc/psbc control=/opt/impora/t1.ctl direct=true
parallel=true &
sqlldr psbc/psbc control=/opt/impora/t2.ctl direct=true
parallel=true &
sqlldr psbc/psbc control=/opt/impora/t3.ctl direct=true
parallel=true &
sqlldr psbc/psbc control=/opt/impora/t4.ctl direct=true
parallel=true &
总结:
首先要确保sqlloader时候的OS两个环境变量的设置
1)NLS_DATE_FORMAT跟你指定的"yyyymmdd
hh24:mi:ss"一样。否则会报日期格式不正确的错误。
2)设置操作系统的环境变量NLS_LANG为AMERICAN_AMERICA.ZHS16GBK,
或者是SIMPLIFIED
CHINESE_CHINA.AL32UTF8,否则可能会产生乱码。
如:
export NLS_LANG="AMERICAN_AMERICA.ZHS16GBK"
export NLS_LANG="AMERICAN_AMERICA.AL32UTF8"
export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"
export NLS_LANG="SIMPLIFIED
CHINESE_CHINA.ZHS32GB18030"
export NLS_LANG='SIMPLIFIED CHINESE_CHINA.AL32UTF8'
export NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS'
其次控制文件中
1、控制文件里的列数一定要和txt文件及其目标表中的实际内容相匹配
2、注意分隔符旁边的空格,因为不考虑的话,默认是把空格也导入进去的,这样因为 STAT_ORG_ID
这列对应的
实际长度是9个字符,而建表的时候指定该列也是9个字符,但是实际导入的过程中,加上空格就超过了9个 字符
3、注意日期格式的数据要对其指定格式。
4、Oracle中与sqlserver
插入日期型数据时,有比较大的区别。sqlserver中,直接把日期型数据用单引号括起来就可以,而Oracle却必须用to_date('',''')这种强类型转换函数显示转换为Date类型。例子:
insert
into employee(id,name,dates)
values(4,'wang',to_date('01-4月-2001','dd-Mon-yyyy'))
insert
into employee(id,name,dates)
values(5,'wang',to_date('01-04-2001','dd-mm-yyyy'))
5、注意:如果数据文件中有的字段为20091231!
即!处没有空格,这种情况也会出错,如果没有!则会提示找不到那一列,而load不进去,这种情况需要修正数据文件中的格式,增加一个空格。
例如20091231!
在vi下用转义符\这样修改
:%s#20091231!#20091231 !#g
注意:如果是往gbase8a里load的话,则不用指定为" !",这样反而会发生格式错误。
6、在往8a导入数据时,gbloader会视20091010的日期数据看做非法数据,需要把源文件里的该日期格式更改成2009-10-10
可以用sed操作,
例如:
sed -i
's/20100228/2010-02-28/g' T98_INDPTY_PROD_STAT.txt
7、若文本文件中日期数据为0000-00-00 00:00:00,则无法sqlldr到oracle
8、加载sql文件时oracle与gbase的不同处
oracle
@/path/xxx.sql
gbase
gbase -u -p < /path/xxx.sql >
/path/xxxx.log
参照下面一片转帖,谢谢作者。
Oracle 的SQL*LOADER可以将外部数据加载到数据库表中。
下面是SQL*LOADER的基本特点:
1)能装入不同数据类型文件及多个数据文件的数据
2)可装入固定格式,自由定界以及可度长格式的数据
3)可以装入二进制,压缩十进制数据
4)一次可对多个表装入数据
5)连接多个物理记录装到一个记录中
6)对一单记录分解再装入到表中
7)可以用 数对制定列生成唯一的KEY
8)可对磁盘或 磁带数据文件装入制表中
9)提供装入错误报告
10)可以将文件中的整型字符串,自动转成压缩十进制并装入列表中。
1.2控制文件
控制文件是用一种语言写的文本文件,这个文本文件能被SQL*LOADER识别。SQL*LOADER根据控制文件可以找到需要加载的数据。并且分析和解释这些数据。控制文件由三个部分组成:
l 全局选件,行,跳过的记录数等;
l INFILE子句指定的输入数据;
l 数据特性说明。
1.3输入文件
对于 SQL*Loader,
除控制文件外就是输入数据。SQL*Loader可从一个或多个指定的文件中读出数据。如果数据是在控制文件中指定,就要在控制文件中写成
INFILE * 格式。
当数据固定的格式(长度一样)时且是在文件中得到时,要用INFILE "fix n"
load data
infile 'example.dat' "fix 11"
into table example
fields terminated by ',' optionally enclosed by '"'
(col1 char(5),
col2 char(7))
example.dat:
001, cd, 0002,fghi,
00003,lmn,
1, "pqrs",
0005,uvwx,
当数据是可变格式(长度不一样)时且是在文件中得到时,要用INFILE "var n"。如:
load data
infile 'example.dat' "var 3"
into table example
fields terminated by ',' optionally enclosed by '"'
(col1 char(5),
col2 char(7))
example.dat:
009hello,cd,010world,im,
012my,name is,
1.4坏文件
坏文件包含那些被SQL*Loader拒绝的记录。被拒绝的记录可能是不符合要求的记录。
坏文件的名字由 SQL*Loader命令的BADFILE 参数来给定。
1.5日志文件及日志信息
当SQL*Loader 开始执行后,它就自动建立 日志文件。日志文件包含有加载的总结,加载中的错误信息等。
控制文件语法
控制文件的格式如下:
OPTIONS ( { [SKIP=integer] [ LOAD = integer ]
[ERRORS = integer] [ROWS=integer]
[BINDSIZE=integer] [SILENT=(ALL|FEEDBACK|ERROR|DISCARD) ] )
LOAD[DATA]
[ { INFILE | INDDN } {file | * }
[STREAM | RECORD | FIXED length [BLOCKSIZE size]|
VARIABLE [length] ]
[ { BADFILE | BADDN } file ]
{DISCARDS | DISCARDMAX} integr ]
[ {INDDN | INFILE} . . . ]
[ APPEND | REPLACE | INSERT ]
[RECLENT integer]
[ { CONCATENATE integer |
CONTINUEIF { [THIS | NEXT] (start[: end])LAST }
Operator { 'string' | X 'hex' } } ]
INTO TABLE [user.]table
[APPEND | REPLACE|INSERT]
[WHEN condition [AND condition]...]
[FIELDS [delimiter] ]
(
column {
RECNUM | CONSTANT value |
SEQUENCE ( { integer | MAX |COUNT} [, increment] ) |
[POSITION ( { start [end] | * [ + integer] }
) ]
datatype
[TERMINATED [ BY ] {WHITESPACE| [X] 'character' } ]
[ [OPTIONALLY] ENCLOSE[BY] [X]'charcter']
[NULLIF condition ]
[DEFAULTIF condotion]
}
[ ,...]
)
[INTO TABLE...]
[BEGINDATA]
1)要加载的数据文件:
1.INFILE 和INDDN是同义词,它们后面都是要加载的数据文件。如果用 * 则表示数据就在控制文件内。在INFILE
后可以跟几个文件。
2.STRAM 表示一次读一个字节的数据。新行代表新物理记录(逻辑记录可由几个物理记录组成)。
3.RECORD 使用宿主操作系统文件及记录管理系统。如果数据在控制文件中则使用这种方法。
3. FIXED length 要读的记录长度为length字节,
4. VARIABLE 被读的记录中前两个字节包含的长度,length 记录可能的长度。缺伤为8k字节。
5. BADFILE和BADDN同义。Oracle 不能加载数据到数据库的那些记录。
6. DISCARDFILE和DISCARDDN是同义词。记录没有通过的数据。
7. DISCARDS和DISCARDMAX是同义词。Integer 为最大放弃的文件个数。
2)加载的方法:
1.APPEND 给表添加行。
2.INSERT 给空表增加行(如果表中有记录则退出)。
3.REPLACE 先清空表在加载数据。
4. RECLEN
用于两种情况,1)SQLLDR不能自动计算记录长度,2)或用户想看坏文件的完整记录时。对于后一种,Oracle只能按常规把坏记录部分写到错误的地方。如果看整条记录,则可以将整条记录写到坏文件中。
3)指定最大的记录长度:
1. CONCATENATE 允许用户设定一个整数,表示要组合逻辑记录的数目。
4)建立逻辑记录:
1.THIS 检查当前记录条件,如果为真则连接下一个记录。
2.NEXT 检查下一个记录条件。如果为真,则连接下一个记录到当前记录来。
2. Start: end 表示要检查在THIS或NEXT字串是否存在继续串的列,以确定是否进行连接。如:continueif
next(1-3)='WAG' 或continueif next(1-3)=X'0d03if'
5)指定要加载的表:
1.INTO TABLE 要加的表名。
2.WHEN 和select WHERE类似。用来检查记录的情况,如:when(3-5)='SSM' and (22)='*"
6)介绍并括起记录中的字段:
1. FIELDS给出记录中字段的分隔符,FIELDS格式为:
FIELDS [TERMIALED [BY] {WHITESPACE | [X] 'charcter'} ]
[ [ OPTIONALLY] ENCLOSE [BY] [X]'charcter' ]
TERMINATED 读完前一个字段即开始读下一个字段直到介绍。
WHITESPACE
是指结束符是空格的意思。包括空格、Tab、换行符、换页符及回车符。如果是要判断但字符,可以用单引号括起,如X'1B'等。
2. OPTIONALLY ENCLOSED
表示数据应由特殊字符括起来。也可以括在TERMINATED字符内。使用OPTIONALLY要同时用TERMINLATED。
ENCLOSED 指两个分界符内的数据。如果同时用 ENCLOSED和TERMINAED ,则它们的顺序决定计算的顺序。
7)定义列:
column 是表列名。列的取值可以是:
BECHUM 表示逻辑记录数。第一个记录为1,第2个记录为2。
CONSTANT 表示赋予常数。
SEQUENCE 表示序列可以从任意序号开始,格式为:
SEQUENCE ( { integer | MAX |COUNT} [,increment]
POSITION 给出列在逻辑记录中的位置。可以是绝对的,或相对前一列的值。格式为:
POSITION ( {start[end] | * [+integer] } )
Start 开始位置
* 表示前字段之后立刻开始。
+ 从前列开始向后条的位置数。
8)定义数据类型:
可以定义14种数据类型:
CHAR
DATE
DECIMAL EXTERNAL
DECIMAL
DOUBLE
FLOAT
FLOAT EXTERNAL
GRAPHIC EXTERNAL
INTEGER
INTEGER EXTERNAL
SMALLINT
VARCHAR
VARGRAPHIC
1.字符类型数据
CHAR[ (length)] [delimiter]
length缺省为 1.
2.日期类型数据
DATE [ ( length)]['date_format' [delimiter]
使用to_date函数来限制。
3.字符格式中的十进制
DECIMAL EXTERNAL [(length)] [delimiter]
用于常规格式的十进制数(不是二进制=> 一个位等于一个bit)。
4.压缩十进制格式数据
DECIMAL (digtial [,divcision])
5.双精度符点二进制
DOUBLE
6.普通符点二进制
FLOAT
7.字符格式符点数
FLOAT EXTERNAL [ (length) ] [delimiter]
8.双字节字符串数据
GRAPHIC [ (legth)]
9.双字节字符串数据
GRAPHIC EXTERNAL[ (legth)]
10.常规全字二进制整数
INTEGER
11.字符格式整数
INTEGER EXTERNAL
12.常规全字二进制数据
SMALLINT
13.可变长度字符串
VARCHAR
14.可变双字节字符串数据
VARGRAPHIC
2.2写控制文件CTL
1. 各数据文件的文件名;
2.各数据文件格式;
3.各数据文件里各数据记录字段的属性;
4.接受数据的ORACLE表列的属性;
5.数据定义;
6.其它
数据文件的要求:
数据类型的指定
CHAR 字符型
INTEGER EXTERNAL 整型
DECIMAL EXTERNAL 浮点型
3.1数据文件的内容
可以在OS下的一个文件;或跟在控制文件下的具体数据。数据文件可以是:
1、 二进制与字符格式:LOADER可以把二进制文件读(当成字符读)列表中
2、 固定格式:记录中的数据、数据类型、 数据长度固定。
3、 可变格式:每个记录至少有一个可变长数据字段,一个记录可以是一个连续的字符串。
数据段的分界(如姓名、年龄)如用“,”作字段的 分 ;用,"’作数据
括号等
4、 LOADER可以使用多个连续字段的物理记录组成一个逻辑记录,记录文件运行情况文件:包括以下内容:
1、 运行日期:软件版本号
2、 全部输入,输出文件名;对命令行的展示信息,补充信息,
3、 对每个装入信息报告:如表名,装入情况;对初始装入, 加截入或更新装
入的选择情况,栏信息
4、 数据错误报告:错误码;放弃记录报告
5、 每个装X报告:装入行;装入行数,可能跳过行数;可能拒绝行数;可能放
弃行数等
6、 统计概要:使用空间(包大小,长度);读入记录数,装入记录数,跳过记
录数;拒绝记录数,放弃记录数;运行时间等。
==================================================================================================
sql load的一点小总结 sqlldr userid=lgone/tiger control=a.ctl LOAD DATA INFILE 't.dat' // 要导入的文件 // INFILE 'tt.date' // 导入多个文件 // INFILE * //
要导入的内容就在control文件里下面的BEGINDATA后面就是导入的内容 INTO TABLE table_name // 指定装入的表 BADFILE 'c:\bad.txt' // 指定坏文件地址 ************* 以下是4种装入表的方式 APPEND // 原先的表有数据 就加在后面 // INSERT // 装载空表 如果原先的表有数据 sqlloader会停止默认值 // REPLACE // 原先的表有数据 原先的数据会全部删除 // TRUNCATE //
指定的内容和replace的相同会用truncate语句删除现存数据 *************
指定的TERMINATED可以在表的开头也可在表的内部字段部分 FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY
'"' // 装载这种数据: 10,lg,"""lg""","lg,lg" // 在表中结果: 10 lg "lg" lg,lg // TERMINATED BY X '09' // 以十六进制格式 '09' 表示的 // TERMINATED BY WRITESPACE // 装载这种数据: 10 lg
lg TRAILING NULLCOLS *************
表的字段没有对应的值时允许为空 ************* 下面是表的字段 ( col_1 , col_2 ,col_filler FILLER // FILLER
关键字此列的数值不会被装载 // 如: lg,lg,not 结果 lg lg ) // 当没声明FIELDS TERMINATED BY ',' 时 // ( // col_1 [interger external] TERMINATED BY ','
, // col_2 [date "dd-mon-yyy"] TERMINATED BY ','
, // col_3 [char] TERMINATED BY ',' OPTIONALLY ENCLOSED BY
'lg' // ) // 当没声明FIELDS TERMINATED BY ','用位置告诉字段装载数据 // ( // col_1 position(1:2), // col_2 position(3:10), // col_3 position(*:16), //
这个字段的开始位置在前一字段的结束位置 // col_4 position(1:16), // col_5 position(3:10) char(8) // 指定字段的类型 // ) BEGINDATA // 对应开始的 INFILE *
要导入的内容就在control文件里 10,Sql,what 20,lg,show ===================================================================================== 注意begindata后的数值前面不能有空格 1 ***** 普通装载 LOAD DATA INFILE * INTO TABLE DEPT REPLACEFIELDS TERMINATED
BY ',' OPTIONALLY ENCLOSED BY '"' (DEPTNO, DNAME, LOC ) BEGINDATA 10,Sales,"""USA""" 20,Accounting,"Virginia,USA" 30,Consulting,Virginia 40,Finance,Virginia 50,"Finance","",Virginia // loc 列将为空 60,"Finance",,Virginia // loc 列将为空 2 ***** FIELDS TERMINATED BY WHITESPACE 和 FIELDS TERMINATED BY
x'09' 的情况 LOAD DATA INFILE * INTO TABLE DEPT REPLACE FIELDS TERMINATED BY WHITESPACE -- FIELDS TERMINATED BY x'09' (DEPTNO, DNAME, LOC ) BEGINDATA 10 Sales Virginia 3 ***** 指定不装载那一列 LOAD DATA INFILE * INTO TABLE DEPT REPLACE FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY
'"' ( DEPTNO, FILLER_1 FILLER, // 下面的 "Something Not To Be Loaded"
将不会被装载 DNAME, LOC ) BEGINDATA 20,Something Not To Be
Loaded,Accounting,"Virginia,USA" 4 ***** position的列子 LOAD DATA INFILE * INTO TABLE DEPT REPLACE ( DEPTNO position(1:2), DNAME position(*:16), //
这个字段的开始位置在前一字段的结束位置 LOC position(*:29), ENTIRE_LINE position(1:29) ) BEGINDATA 10Accounting Virginia,USA 5 ***** 使用函数 日期的一种表达 TRAILING NULLCOLS的使用 LOAD DATA INFILE * INTO TABLE DEPT REPLACE FIELDS TERMINATED BY ',' TRAILING NULLCOLS //
其实下面的ENTIRE_LINE在BEGINDATA后面的数据中是没有直接对应 // 的列的值的 如果第一行改为 10,Sales,Virginia,1/5/2000,, 就不用TRAILING
NULLCOLS了 (DEPTNO, DNAME "upper(:dname)", // 使用函数 LOC "upper(:loc)", LAST_UPDATED date 'dd/mm/yyyy', // 日期的一种表达方式 还有'dd-mon-yyyy'
等 ENTIRE_LINE
":deptno||:dname||:loc||:last_updated" ) BEGINDATA 10,Sales,Virginia,1/5/2000 20,Accounting,Virginia,21/6/1999 30,Consulting,Virginia,5/1/2000 40,Finance,Virginia,15/3/2001 6 ***** 使用自定义的函数 // 解决的时间问题 create or replace function my_to_date( p_string in varchar2 ) return
date as type fmtArray is table of varchar2(25); l_fmts fmtArray := fmtArray( 'dd-mon-yyyy',
'dd-month-yyyy', 'dd/mm/yyyy', 'dd/mm/yyyy hh24:mi:ss' ); l_return date; begin for i in 1 .. l_fmts.count loop begin l_return := to_date( p_string, l_fmts(i) ); exception when others then null; end; EXIT when l_return is not null; end loop; if ( l_return is null ) then l_return := new_time( to_date('01011970','ddmmyyyy') + 1/24/60/60
* p_string, 'GMT', 'EST' ); end if; return l_return; end; / LOAD DATA INFILE * INTO TABLE DEPT REPLACE FIELDS TERMINATED BY ',' TRAILING NULLCOLS (DEPTNO, DNAME "upper(:dname)", LOC "upper(:loc)", LAST_UPDATED "my_to_date( :last_updated )" //
使用自定义的函数 ) BEGINDATA 10,Sales,Virginia,01-april-2001 20,Accounting,Virginia,13/04/2001 30,Consulting,Virginia,14/04/2001 12:02:02 40,Finance,Virginia,987268297 50,Finance,Virginia,02-apr-2001 60,Finance,Virginia,Not a date 7 ***** 合并多行记录为一行记录 LOAD DATA INFILE * concatenate 3 // 通过关键字concatenate
把几行的记录看成一行记录 INTO TABLE DEPT replace FIELDS TERMINATED BY ',' (DEPTNO, DNAME "upper(:dname)", LOC "upper(:loc)", LAST_UPDATED date 'dd/mm/yyyy' ) BEGINDATA 10,Sales, // 其实这3行看成一行
10,Sales,Virginia,1/5/2000 Virginia, 1/5/2000 // 这列子用 continueif list="," 也可以 告诉sqlldr在每行的末尾找逗号 找到逗号就把下一行附加到上一行 LOAD DATA INFILE * continueif this(1:1) = '-' // 找每行的开始是否有连接字符 -
有就把下一行连接为一行 // 如 -10,Sales,Virginia, // 1/5/2000 就是一行 10,Sales,Virginia,1/5/2000 // 其中1:1 表示从第一行开始 并在第一行结束 还有continueif next 但continueif
list最理想 INTO TABLE DEPT replace FIELDS TERMINATED BY ',' (DEPTNO, DNAME "upper(:dname)", LOC "upper(:loc)", LAST_UPDATED date 'dd/mm/yyyy' ) BEGINDATA // 但是好象不能象右面的那样使用 -10,Sales,Virginia, -10,Sales,Virginia, 1/5/2000 1/5/2000 -40, 40,Finance,Virginia,13/04/2001 Finance,Virginia,13/04/2001
8 ***** 载入每行的行号 load data infile * into table t replace ( seqno RECNUM //载入每行的行号 text Position(1:1024)) BEGINDATA fsdfasj //自动分配一行号给载入 表t 的seqno字段 此行为 1 fasdjfasdfl // 此行为 2 ... 9 ***** 载入有换行符的数据 注意: unix 和 windows 不同 \\n &
/n < 1 >
使用一个非换行符的字符 LOAD DATA INFILE * INTO TABLE DEPT REPLACE FIELDS TERMINATED BY ',' TRAILING NULLCOLS (DEPTNO, DNAME "upper(:dname)", LOC "upper(:loc)", LAST_UPDATED "my_to_date( :last_updated )", COMMENTS "replace(:comments,'\n',chr(10))" // replace
的使用帮助转换换行符
oracle sqlldr decode,sqlldr时遇到的一个问题相关推荐
- oracle怎么自定义排序,查询时怎么根据一个自定义的函数来进行排序
查询时如何根据一个自定义的函数来进行排序 如何写一个函数将IP地址转化为十进制数字的函数IPTONuM然后当查询iptable的时候根据IPTONuM得到的结果进行排序 [iptable表不仅有IP地 ...
- 先随机后排序的oracle,Oracle用decode函数或CASE-WHEN实现自定义排序
Oracle用decode函数或CASE-WHEN实现自定义排序 1 问题 对SQL排序,只要在order by后面加字段就可以了,可以通过加desc或asc来选择降序或升序.但排序规则是默认的,数字 ...
- oracle中DECODE与CASE的用法区别
对于CASE与DECODE其实并没有太多的区别,他们都是用来实现逻辑判断.Oracle的DECODE函数功能很强,灵活运用的话可以避免多次扫描,从而提高查询的性能.而CASE是9i以后提供的语法,这个 ...
- oracle使用decode实现竖表转横表 (列转行)
工作中时长会用到竖表转横表(列转行)例如某商场每天都有营业额,数据库中营业额存储的方式是每天很多比每笔对应不同的消费记录 ,可能有一天的营业额很多 对应的营业额明细就会很多,如果有个需求是要统计每天营 ...
- oracle+decode函数用法,oracle中decode函数用法
oracle中decode函数用法以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! DECODE函数相当于一条件语句(IF ...
- oracle 中decode函数
Oracle 中 decode 函数用法 含义解释: decode(条件,值1,返回值1,值2,返回值2,-值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN RETURN(翻译 ...
- mysql中 translate_mysql实现oracle的decode和translate以及管道符拼接
mysql实现oracle的decode和translate以及管道符拼接 发布时间:2020-08-14 03:58:04 来源:ITPUB博客 阅读:122 作者:贺子_DBA时代 目前要把网站整 ...
- oracle 数据有引号,oracle插入字符串数据时字符串中有'单引号问题
使用insert into(field1,field2...) values('val1','val2'...)时,若值中有单引号时会报错. 处理方法:判断一下val1,val2中是否含有单引号,若含 ...
- mysql自定义函数实现,自定义oracle中decode方法
要想知道怎么定义第一步要知道oracle中decode是怎么实现呢? decode(expression,value1,result1,value2,result2,value3,result3-,d ...
- Oracle数据库表设计时的注意事项
Oracle数据库表设计时的注意事项 表是Oracle数据库中最基本的对象之一.万丈高楼从平地起,这个基础对象对于数据库来说,非常重要.因为其设计是否合理,直接跟数据库的性能相关.从Oracle数据 ...
最新文章
- 条款02:尽量以const,enum,inline代替#define
- https Java SSLException protocol_version的问题解决方法
- ubuntu18安装nginx没有生成各类目录文件问题解决
- linux中c语言生日快乐_生日快乐,Linux:27岁
- qt中append函数_Qt 加载cern-root库 并调用root类
- centos PIL 安装
- 设备像素比devicePixelRatio简单介绍
- NullableTypes for .NET
- 网上摘的数据缓存资料
- kali更新grub修复双系统windows10引导启动项
- 游园惊梦--记游第九届软博会
- Unity 知识点复习
- 高中数学培训高中数学必修一
- Docker所在目录以及查询正在运行容器的所在位置
- SSM框架和SpringBoot框架的对比
- 射频器件厂商RFMD与TriQuint达成合并协议
- keil新建库函数模板
- C++计算机高级程序设计语言
- Android ADB超简单的安装方法
- Oracle用户名有引号,关于oracle sql 中as与双引号的一点有趣故事
热门文章
- Python 全栈打造某宝客微信机器人
- 九歌计算机在线作诗硬件原理,矣晓沅,孙茂松:计算机的诗意 | 机器写诗的背后...
- 计算机病毒与木马的区别,计算机病毒和木马的区别
- 电驴v1.2.2.45574最新版官方下载
- nand flash与烧录器
- 使用ACCESS数据库时出现“操作必须使用一个可更新的查询”的解决办法
- pve万兆网卡驱动_网卡的正确选择,避开小白踩坑
- 论现场跟客户演示软件产品
- 约翰·库缇斯(没有双腿的激励大师,年轻人必看)转载
- FlashFXP,flashfxp安装