Datastage 中Transformer Stage:各个函数的解析

Transformer Stage:各个函数的意义:

Date$Time

函数名称
 测试用列
 描述
 测试结果
 
CurrentDate
 CurrentDate()
 获取系统当天日期
 2008-08-05
 
CurrentTime
 CurrentTime()
 获取系统当天时间
 17:52:31
 
CurrentTimestamp
 CurrentTimestamp()
 获取系统当天日期时间
 2008-08-05 17:52:31
 
HoursFromTime
 HoursFromTime(’08:01:02’)
 获取小时
 8
 
JulianDayFromDate
 JulianDayFromDate(‘2008-08-05’)
 
 2454685
 
MicroSecondsFromTime
 MicroSecondsFromTime(‘17:52:31’)
 返回一个微妙数
 0
 
MinutesFromTime
 MinutesFromTime('14:24:45')
 返回一个分钟数
 24
 
MonthDayFromDate
 MonthDayFromDate("2008-08-13")
 返回当月的第几天
 13
 
DateFromDaysSince
 DateFromDaysSince('13',"2008-08-12")
 返回当天时间被加后的日期类型
 2008-08-25
 
MonthFromDate
 MonthFromDate('2008-09-01')
 返回当月的月
 9
 
NextWeekdayFromDate
 NextWeekdayFromDate('2008-08-10','Thursday')
 传入当月当天日期返回得到传入星期几的下一个日期几
 2008-08-14
 
PreviousWeekdayFromDate
 PreviousWeekdayFromDate('2008-08-10','Wednesday')
 传入当月当天日期返回得到传入星期几的上一个日期几
 2008-08-06
 
SecondsFromTime
 SecondsFromTime('17:23:44')
 传入时间返回时间的秒数
 44
 
SecondsSinceFromTimestamp
 SecondsSinceFromTimestamp('2008-08-06 10:01:31','2008-08-19 09:12:31')
 返回两个日期的比较后得出的秒数
 -1.12026e+06 =

-1120260
 
TimeDate
 TimeDate()
 获取系统时间以时间,日,月,年显示
 14:07:50 06 Aug 2008
 
TimeFromMidnightSeconds
 TimeFromMidnightSeconds('120')
 传入秒数获得以计算秒为时间单位的时间
 00:02:00
 
TimestampFromDateTime
 TimestampFromDateTime('2008-09-01','07:30:41')
 传入日期,时间整合返回Timestamp
 2008-09-01 07:30:41
 
TimestampFromSecondsSince
 TimestampFromSecondsSince('120','2008-08-07 11:12:13')
 传入秒数,Timestamp后返回将秒数累加到Timestamp类型上
 2008-08-07 11:14:13
 
TimestampFromTimet
 TimestampFromTimet('120')
 传入秒数返回一个unix上的timestamp类型
 1970-01-01 00:02:00
 
TimetFromTimestamp
 TimetFromTimestamp('1970-01-01 00:02:00')
 传入timestamp类型返回unix time_t
 120
 
WeekdayFromDate
 WeekdayFromDate('2008-08-09','Wednesday')
 传入日期和星期几返回传入日期当前星期(星期天排除为当前星期)的天数,向上查询
 3
 
YeardayFromDate
 YeardayFromDate('2008-09-09')
 传入日期返回传入日期的当天数
 253
 
YearFromDate
 YearFromDate('2008-09-09')
 传入日期返回年份数
 2008
 
YearweekFromDate
 YearweekFromDate('2008-09-09')
 传入日期返回传入日期的所在周数
 37
 
IsValid
 if IsValid('int32', CUSTOMER) then AsInteger(DSLink2.TXN_CNT) else ''

 

if IsValid('dfloat',DSLink2.TXN_AMT) then DSLink2.TXN_AMT else ''
 传入一个参数和他的匹配类型,如果匹配就输出,不匹配则为空

"date", "decimal",

"dfloat", "sfloat", "int8", "uint8","int16", "uint16", "int32","uint32", "int64", "uint64", "raw","string", "time", "timestamp"."ustring"
 123

 

 

0000123.
 

 

Logicl

函数名称
 测试用列
 描述
 测试结果
 
BitAnd
 BitAnd(235,25)

11101011  ---235

00011001  ---25

00001001  --9

 
 传入两个int型参数,将他们转化为二进制,通过“或”关系将最后参数返回,当为1与0比为0,1与1比为1
 9
 
BitCompress
 if BitCompress(0)=0 then 0 else 1
 传入的参数只能为1或0,当条件成立返回1
 0
 
BitOr
 BitOr (321,123)

101000001  ---321

001111011  ---123

101111011  ---379
 传入两个int型参数,将他们转化为二进制,通过“与”关系将最后参数返回,当为1与0比为1,1与1比为1
 379
 
BitXOr
 BitXOr(321,123)

101000001  ---321

001111011  ---123

100111010  ---314
 传入两个int型参数,将他们转化为二进制,当1与0比为1,1与1比为0
 314
 
Not
 Not(1=1)
 判断表达式,如果为真返回为0,如果为假返回为1
 0
 

 

Number

函数名称
 测试用列
 描述
 测试结果
 
AsDouble
 AsDouble(12.123456)
 保留4为小数最后一位四舍五入
 12.1235
 
AsFloat
 AsFloat(13.654321)
 保留4为小数最后一位四舍五入
 13.6543
 
AsInteger
 AsInteger(11.23)
 传入小数返回整数
 11
 
MantissaFromDecimal
 MantissaFromDecimal(15.123456)
 取小数尾数
 1.23456e+09

1234560000
 
MantissaFromDFloat
 MantissaFromDFloat(16.22222)
 取小数尾数
 2222
 

 

String

函数名称
 测试用列
 描述
 测试结果
 
AlNum
 AlNum('Sting12')
 传入的参数如果string类型返回1
 1
 
Alpha
 Alpha('String')
 传入的参数为必须为string不能带有其他字符,如果有则为0
 1
 
CompactWhiteSpace
 CompactWhiteSpace('Str ing'):' ':CompactWhiteSpace('a bc d'):' ':CompactWhiteSpace('A B C D')
 将多个字符串类型串联为一个类型
 Str ing a bc d A B C D
 
Compare
 Compare('abc','def','L'):' ':Compare('def','abc','R'):' ':Compare('qwer','qwer','R')
 比较字符串大小,按照ascII比较方式
 -1

1

0
 
CompareNoCase
 CompareNoCase('B','C'):' ':CompareNoCase('a','a')
 比较两个字符串是否相等,相等为0,不相等为-1
 -1

0
 
CompareNum
 CompareNum('A','B',1):' ':CompareNum('B','B',1):' ':CompareNum('abc','cde',3):' ':CompareNum('abcd','a',4)
 比较传入的参数,如果绝对相同为0,传入的arg2包含在传入的arg1中为1,不相等为-1
 -1

0

-1

1
 
Convert
 Convert('bd','12', 'abcdefghijk')
 Arg1查找的参数,arg2是需要修改为的参数。最后返回修改后的结果
 a1c2efghijk
 
Count
 Count('jxj','j')
 获取相同字符的合计
 2
 
Dcount
 Dcount('jxj','j')
 获取相同字符的合计然后再加1
 3
 
DownCase
 DownCase('ACRM123ACrm123acRM')
 将字符中的大写转化为小写
 acrm123acrm123acrm
 
DQuote
 DQuote('abcd':'mnb'):'123'
 将两个字符串连接起来用双引包括
 "abcdmnb"123
 
Field
 Field('parallel','l',3)
 将字符串中的字符串取出来
 e
 
Index
 Index('a;lkdfjioquejrlkjasopdifu','j',2)
 索引字符串’j’直到发现第2个’j’的时候停止并返回长度
 13
 
Left
 Left('abcdefghijk',4)
 从左边取4位字符串
 abcd
 
Right
 Right('abcdefghijk',4)
 从右边取4位字符串
 hijk
 
Len
 Len('asdlkfjalsdf')
 返回字符串的长度
 12
 
Num
 Num(1234)
 如果是数字返回为1,非数字返回为0
 1
 
PadString
 PadString('abcd','acr',3)
 第一个参数为输出参数,第二个为追加参数(只取字符串的第一位),第3个为追加几次
 abcdaaa
 
Soundex
 Soundex('longtop')
 通过英文发音的比对来获取
 L523
 
 
 
 
 
 
Squote
 Squote('asdfasdf':'12')
 将传入的字符串想通过单引号包括
 'asdfasdf12'
 
Str
 Str("A", 20 - Len('asd'))
 将传入第一个参数和后面数字做联系,复制第一参数
 AAAAAAAAAAAAAAAAA
 
Space
 Space(10 - Len('asdf'))
 追加空格
 ‘      ‘
 
StripWhiteSpace
 StripWhiteSpace('ab e q w e r')
 将字符串中所有的空格去掉
 abeqwer
 
Trim
 Trim(' askd  ')

Trim('   kk   a  b c  ',' ')

Trim('   kk   a  b c  ',' ','A')

Trim('   kk   a  b c  ',' ','L')

Trim('   kk   a  b c  ',' ','B')

Trim('   kk   a  b c  ',' ','R')

Trim('   kk   a  b c  ',' ','F')

Trim('   kk   a  b c  ',' ','E')

Trim('   kk   a  b c  ',' ','D')
 去除左右两边空格

去除多余的空格

去除全部的空格

去除左右的空格

去除左右两边

去左右两边和多余空格

去除左边空格

去除右边空格

去除多余的空格
 askd

kk a b c

kkabc

kk   a  b c 

kk   a  b c

kk a b c

kk   a  b c 

   kk   a  b c

kk a b c
 
TrimB
 TrimB('  kkkk  ')
 去除右边的空格
   kkkk
 
TrimF
 TrimF('  kkkk  ')
 去除左边的空格
 kkkk 
 
TrimLeadingTrailing
 TrimLeadingTrailing('  k k k k  ')
 去除左右两边空格删除第一和最后的空格
 k k k k
 
UpCase
 UpCase('abcd')
 将所有小写转换为大写
 ABCD
 

 

 

 

函数名称
 测试用列
 描述
 测试结果
 
Char
 Char(123)
 将数字转化为对应的ASCII码
 {
 
DateToString
 DateToString('2008-08-01',"%yyyy-%mm-%dd")
 将日期转化为字符
 2008-08-01
 
DecimalToDecimal
 DecimalToDecimal(13.55)
 将decimecl类型转化为decimal类型
 0000000000000000000000000013.5500000000
 
DecimalToDFloat
 DecimalToDFloat(13.5678897866854464)
 将decimecl类型转化为float类型并四舍五入
 13.5679
 
DecimalToString
 DecimalToString(123.567)
 将decimecl类型转化为string类型输出
 0000000000000000000000000123.5670000000
 
DFloatToDecimal
 DFloatToDecimal(12.5658)
 将float转化为decimal类型
 0000000000000000000000000012.5658000000
 
DFloatToStringNoExp
 DFloatToStringNoExp(29.10,'2'):' ':DFloatToStringNoExp(29.120,'3'):' ':DFloatToStringNoExp(29.120,'4')
 取dfloat的位数并转化为string输出
 29

29.12

29.12
 
Seq
 Seq ('A'):' ':Seq('B')
 将传入的字符转化为相对应的ASCII数字
 65 66
 
StringToDate
 StringToDate('19821114',"%yyyy%mm%dd")
 将字符类型的日期转化为日期类型输出
 1982-11-14
 
StringToDecimal
 StringToDecimal('12.345','ceil'):' ':StringToDecimal('12.345','floor')
 得到最大的。

得到最小的。
 0000000000000000000000000012.3450000000 

000
 
StringToTime
 StringToTime('081114',"%hh%nn%ss")
 将字符类型的时间转化为时间类型
 08:11:14
 
StringToTimestamp
 StringToTimestamp('19261212 001245',"%yyyy%mm%dd %hh%nn%ss")
 将字符的timestamp类型转化为timestamp类型
 1926-12-12 00:12:45
 
TimestampToDate
 TimestampToDate(CurrentTimestamp())
 将timestamp转化为日期类型
 2008-08-12
 
TimestampToString
 TimestampToString(CurrentTimestamp(),"%yyyy/%mm/%dd %hh/%nn/%ss")
 将日期类型按照返回的格式转化为字符类型
 2008/08/12 15/18/18
 
TimestampToTime
 TimestampToTime(CurrentTimestamp())
 将timestamp转化为时间类型
 15:18:18
 
TimeToString
 TimeToString(CurrentTime(),"%hh-%nn-%ss")
 将时间类型按照返回的格式转化为字符类型
 15-18-18
 
StringToUString
 StringToUString('Ustring')
 将string类型转化为Ustring类型(Char, varchar, longvarchar)
 Ustring
 
UStringToString
 UStringToString('string')
 将Ustring(Char, varchar, longvarchar)类型转化为string类型
 string
 


 

你可能感兴趣的:(datastage)