文档中心MogDBMogDB StackUqbar
v5.0

文档:v5.0

支持的版本:

其他版本:

类型转换函数(一)

  • cash_words(money)

    描述:类型转换函数,将money转换成text。

    示例:

    MogDB=# SELECT cash_words('1.23');
                cash_words
    -----------------------------------
     One dollar and twenty three cents
    (1 row)
  • cast(x as y)

    描述:类型转换函数,将x转换成y指定的类型。

    示例:

    MogDB=# SELECT cast('22-oct-1997' as timestamp);
          timestamp
    ---------------------
     1997-10-22 00:00:00
    (1 row)
  • hextoraw(raw)

    描述:将一个十六进制构成的字符串转换为raw类型。

    返回值类型:raw

    示例:

    MogDB=# SELECT hextoraw('7D');
     hextoraw
    ----------
     7D
    (1 row)
  • numtoday(numeric)

    描述:将数字类型的值转换为指定格式的时间戳。

    返回值类型:timestamp

    示例:

    MogDB=# SELECT numtoday(2);
     numtoday
    ----------
     2 days
    (1 row)
  • pg_systimestamp()

    描述:获取系统时间戳。

    返回值类型:timestamp with time zone

    示例:

    MogDB=# SELECT pg_systimestamp();
            pg_systimestamp
    -------------------------------
     2015-10-14 11:21:28.317367+08
    (1 row)
  • rawtohex(string)

    描述:将一个二进制构成的字符串转换为十六进制的字符串。

    结果为输入字符的ACSII码,以十六进制表示。

    返回值类型:varchar

    示例:

    MogDB=# SELECT rawtohex('1234567');
        rawtohex
    ----------------
     31323334353637
    (1 row)
  • to_bigint(varchar)

    描述:将字符类型转换为bigint类型。

    返回值类型:bigint

    示例:

    MogDB=# SELECT to_bigint('123364545554455');
        to_bigint
    ----------------
     123364545554455
    (1 row)
  • to_char (datetime/interval [, fmt])

    描述:将一个DATE、TIMESTAMP、TIMESTAMP WITH TIME ZONE或者TIMESTAMP WITH LOCAL TIME ZONE类型的DATETIME或者INTERVAL值按照fmt指定的格式转换为TEXT类型。

    • 可选参数fmt可以为以下几类:日期、时间、星期、季度和世纪。每类都可以有不同的模板,模板之间可以合理组合,常见的模板有:HH、MM、SS、YYYY、MM、DD。
    • 模板可以有修饰词,常用的修饰词是FM,可以用来抑制前导的零或尾随的空白。
    • 对于TIMESTAMP WITH TIME ZONE,可以在to_char使用TZH、TZM、TZD、TZR参数来输出时区信息。

    返回值类型:text

    示例:

    MogDB=# SELECT to_char(current_timestamp,'HH12:MI:SS');
     to_char
    ----------
     10:19:26
    (1 row)
    MogDB=# SELECT to_char(current_timestamp,'FMHH12:FMMI:FMSS');
     to_char
    ----------
     10:19:46
    (1 row)
    
    MogDB=# select to_char(systimestamp, 'TZH');
    to_char
    ---------
    +08
    (1 row)
    
    MogDB=# select to_char(systimestamp, 'TZM');
    to_char
    ---------
    00
    (1 row)
    
    MogDB=# select to_char(systimestamp, 'TZD');
    to_char
    ---------
    CST
    (1 row)
    
    MogDB=# select to_char(systimestamp, 'TZR');
    to_char
    ---------------
    Asia/Shanghai
    (1 row)

    表 1 日期/时间格式化的模版模式

    模式 描述
    HH 一天的小时数 (01-12)
    HH12 一天的小时数 (01-12)
    HH24 一天的小时数 (00-23)
    MI 分钟 (00-59)
    SS 秒 (00-59)
    MS 毫秒 (000-999)
    US 微妙 (000000-999999)
    SSSS 午夜之后的秒数(0-86399)
    AMamPMpm 子午线 Metrics(无期限)
    A.M.a.m.P.M.p.m. 子午线 Metrics(带句号)
    Y,YYY 年份(4 个或更多数字),带逗号
    YYYY 年(4 个或更多数字)
    YYY 年份的后三位数
    YY 年份的后两位数字
    Y 年份的最后一位
    IYYY ISO 8601 周编号年份(4 个或更多数字)
    IYY ISO 8601 周编号年份的后 3 位数字
    IY ISO 8601 周编号年份的后两位数字
    I ISO 8601 周编号年的最后一位数字
    BCbcADad 时代 Metrics(无期限)
    B.C.b.c.A.D.a.d. 时代 Metrics(带句号)
    MONTH 完整的大写月份名称(空格填充为 9 个字符)
    Month 完整的大写月份名称(空白,最多 9 个字符)
    month 完整的小写月份名称(空格填充为 9 个字符)
    MON 大写月份名称的缩写(英语为 3 个字符,本地化长度有所不同)
    Mon 缩写的大写月份名称(英文为 3 个字符,本地化长度有所不同)
    mon 小写的月份缩写名称(英语为 3 个字符,本地化长度有所不同)
    MM 月数(01-12)
    DAY 完整的大写日期名称(空白,最多 9 个字符)
    Day 完整的大写日期名称(空白,最多 9 个字符)
    day 完整的小写日期名称(空白,最多 9 个字符)
    DY 缩写的大写星期名称(英语为 3 个字符,本地化长度有所不同)
    Dy 缩写的大写星期名称(英语为 3 个字符,本地化长度有所不同)
    dy 缩写的小写星期名称(英语为 3 个字符,本地化长度有所不同)
    DDD 一年中的哪一天(001-366)
    IDDD ISO 8601 周编号年份的天(001-371;一年中的第 1 天是第一个 ISO 周的星期一)
    DD 每月的一天(01-31)
    D 星期几,星期日(1)至星期六(7)
    ID ISO 8601 是星期几,星期一(1)至星期日(7)
    W 一个月中的第几周(1-5)(第一个星期从该月的第一天开始)
    WW 年的周数(1-53)(第一周从一年的第一天开始)
    IW ISO 8601 周编号年的周号(01-53;该年的第一个星期四在第 1 周)
    CC 世纪(2 位数字)(二十一世纪始于 2001-01-01)
    J 朱利安日(自公元前 4714 年 11 月 24 日午夜 UTC 以来的整数天)
    Q quarter
    RM 大写罗马数字表示月份(I-XII; I =一月)
    rm 小写罗马数字表示月份(i-xii; i =一月)
    TZ 大写的时区缩写(仅在to_char中受支持)
    tz 小写的时区缩写(仅在to_char中受支持)
    TZH 时区的小时
    TZM 时区的分钟
    TZD 夏令时信息
    TZR 时区区域信息
  • to_char(double precision/real, text)

    描述:将浮点类型的值转换为指定格式的字符串。

    返回值类型:text

    示例:

    MogDB=# SELECT to_char(125.8::real, '999D99');
     to_char
    ---------
      125.80
    (1 row)
  • to_char(numeric/smallint/integer/bigint/double precision/real[, fmt])

    描述:将一个整型或者浮点类型的值转换为指定格式的字符串。

    • 可选参数fmt可以为以下几类:十进制字符、"分组"符、正负号和货币符号,每类都可以有不同的模板,模板之间可以合理组合,常见的模板有:9、0、,(千分隔符)、.(小数点)。
    • 模板可以有类似FM的修饰词,但FM不抑制由模板0指定而输出的0。
    • 要将整型类型的值转换成对应16进制值的字符串,使用模板X或x。

    返回值类型:varchar

    示例:

    MogDB=# SELECT to_char(1485,'9,999');
     to_char
    ---------
      1,485
    (1 row)
    MogDB=# SELECT to_char( 1148.5,'9,999.999');
      to_char
    ------------
      1,148.500
    (1 row)
    MogDB=# SELECT to_char(148.5,'990999.909');
       to_char
    -------------
        0148.500
    (1 row)
    MogDB=# SELECT to_char(123,'XXX');
     to_char
    ---------
       7B
    (1 row)
  • to_char(interval, text)

    描述:将时间间隔类型的值转换为指定格式的字符串。

    返回值类型:text

    示例:

    MogDB=# SELECT to_char(interval '15h 2m 12s', 'HH24:MI:SS');
     to_char
    ----------
     15:02:12
    (1 row)
  • to_char(int, text)

    描述:将整数类型的值转换为指定格式的字符串。

    返回值类型:text

    示例:

    MogDB=# SELECT to_char(125, '999');
     to_char
    ---------
      125
    (1 row)
  • to_char(set)

    描述:将SET类型的值转换为指定格式的字符串。

    返回值类型:text

    示例:

    - site是employee的SET类型的字段 
         
    MogDB=# select to_char(site) from employee;
     to_char
     ---------
      beijing,nanjing
      beijing,wuhan
    (2 rows)
  • to_char(numeric, text)

    描述:将数字类型的值转换为指定格式的字符串。

    返回值类型:text

    示例:

    MogDB=# SELECT to_char(-125.8, '999D99S');
     to_char
    ---------
     125.80-
    (1 row)
  • to_char (string)

    描述:将CHAR、VARCHAR、VARCHAR2、CLOB类型转换为VARCHAR类型。

    如使用该函数对CLOB类型进行转换,且待转换CLOB类型的值超出目标类型的范围,则返回错误。

    返回值类型:varchar

    示例:

    MogDB=# SELECT to_char('01110');
     to_char
    ---------
     01110
    (1 row)
  • to_char(timestamp, text)

    描述:将时间戳类型的值转换为指定格式的字符串。

    返回值类型:text

    示例:

    MogDB=# SELECT to_char(current_timestamp, 'HH12:MI:SS');
     to_char
    ----------
     10:55:59
    (1 row)
  • to_clob(char/nchar/varchar/varchar2/nvarchar/nvarchar2/text/raw)

    描述:将RAW类型或者文本字符集类型CHAR、NCHAR、VARCHAR、VARCHAR2、NVARCHAR、NVARCHAR2、TEXT转成CLOB类型。

    返回值类型:clob

    示例:

    MogDB=# SELECT to_clob('ABCDEF'::RAW(10));
     to_clob
    ---------
     ABCDEF
    (1 row)
    MogDB=# SELECT to_clob('hello111'::CHAR(15));
     to_clob
    ----------
     hello111
    (1 row)
    MogDB=# SELECT to_clob('gauss123'::NCHAR(10));
     to_clob
    ----------
     gauss123
    (1 row)
    MogDB=# SELECT to_clob('gauss234'::VARCHAR(10));
     to_clob
    ----------
     gauss234
    (1 row)
    MogDB=# SELECT to_clob('gauss345'::VARCHAR2(10));
     to_clob
    ----------
     gauss345
    (1 row)
    MogDB=# SELECT to_clob('gauss456'::NVARCHAR2(10));
     to_clob
    ----------
     gauss456
    (1 row)
    MogDB=# SELECT to_clob('World222!'::TEXT);
      to_clob
    -----------
     World222!
    (1 row)
  • to_date(text)

    描述:将文本类型的值转换为指定格式的时间戳。目前只支持两类格式。

    • 格式一:无分隔符日期,如20150814,需要包括完整的年月日。

    • 格式二:带分隔符日期,如2014-08-14,分隔符可以是单个任意非数字字符。

    返回值类型:timestamp without time zone

    示例:

      MogDB=# SELECT to_date('2015-08-14');
             to_date
      ---------------------
       2015-08-14 00:00:00
      (1 row)
  • to_date(text, text)

    描述:将字符串类型的值转换为指定格式的日期。

    返回值类型:timestamp without time zone

    示例:

    MogDB=# SELECT to_date('05 Dec 2000', 'DD Mon YYYY');
           to_date
    ---------------------
     2000-12-05 00:00:00
    (1 row)
  • to_number ( expr [, fmt])

    描述:将expr按指定格式转换为一个NUMBER类型的值。

    类型转换格式请参考表2

    转换十六进制字符串为十进制数字时,最多支持16个字节的十六进制字符串转换为无符号数。

    转换十六进制字符串为十进制数字时,格式字符串中不允许出现除'x'或'X'以外的其他字符,否则报错。

    返回值类型:number

    示例:

    MogDB=# SELECT to_number('12,454.8-', '99G999D9S');
     to_number
    -----------
      -12454.8
    (1 row)
  • to_number(text, text)

    描述:将字符串类型的值转换为指定格式的数字。

    返回值类型:numeric

    示例:

    MogDB=# SELECT to_number('12,454.8-', '99G999D9S');
     to_number
    -----------
      -12454.8
    (1 row)
  • to_timestamp(double precision)

    描述:把UNIX纪元转换成时间戳。

    返回值类型:timestamp with time zone

    示例:

    MogDB=# SELECT to_timestamp(1284352323);
          to_timestamp
    ------------------------
     2010-09-13 12:32:03+08
    (1 row)
  • to_timestamp(string [,fmt])

    描述:将字符串string按fmt指定的格式转换成时间戳类型的值。不指定fmt时,按参数nls_timestamp_format所指定的格式转换。

    MogDB的to_timestamp中,

    • 如果输入的年份YYYY=0,系统报错。
    • 如果输入的年份YYYY<0,在fmt中指定SYYYY,则正确输出公元前绝对值n的年份。

    fmt中出现的字符必须与日期/时间格式化的模式相匹配,否则报错。

    返回值类型:timestamp without time zone

    示例:

    MogDB=# SHOW nls_timestamp_format;
        nls_timestamp_format
    ----------------------------
     DD-Mon-YYYY HH:MI:SS.FF AM
    (1 row)
    
    MogDB=# SELECT to_timestamp('12-sep-2014');
        to_timestamp
    ---------------------
     2014-09-12 00:00:00
    (1 row)
    MogDB=# SELECT to_timestamp('12-Sep-10 14:10:10.123000','DD-Mon-YY HH24:MI:SS.FF');
          to_timestamp
    -------------------------
     2010-09-12 14:10:10.123
    (1 row)
    MogDB=# SELECT to_timestamp('-1','SYYYY');
          to_timestamp
    ------------------------
     0001-01-01 00:00:00 BC
    (1 row)
    MogDB=# SELECT to_timestamp('98','RR');
        to_timestamp
    ---------------------
     1998-01-01 00:00:00
    (1 row)
    MogDB=# SELECT to_timestamp('01','RR');
        to_timestamp
    ---------------------
     2001-01-01 00:00:00
    (1 row)
  • to_timestamp(text, text)

    描述:将字符串类型的值转换为指定格式的时间戳。

    返回值类型:timestamp

    示例:

    MogDB=# SELECT to_timestamp('05 Dec 2000', 'DD Mon YYYY');
        to_timestamp
    ---------------------
     2000-12-05 00:00:00
    (1 row)

表 2 数值格式化的模版模式

模式 描述
9 带有指定数值位数的值
0 带前导零的值
.(句点) 小数点
,(逗号) 分组(千)分隔符
PR 尖括号内负值
S 带符号的数值(使用区域设置)
L 货币符号(使用区域设置)
D 小数点(使用区域设置)
G 分组分隔符(使用区域设置)
MI 在指明的位置的负号(如果数字 < 0)
PL 在指明的位置的正号(如果数字 > 0)
SG 在指明的位置的正/负号
RN 罗马数字(输入在 1 和 3999 之间)
TH或th 序数后缀
V 移动指定位(小数)
  • abstime_text

    描述:将abstime类型转为text类型输出。

    参数:abstime

    返回值类型:text

  • abstime_to_smalldatetime

    描述:将abstime类型转为smalldatatime类型。

    参数:abstime

    返回值类型:smalldatetime

  • bigint_tid

    描述:将bigint转为tid。

    参数:bigint

    返回值类型:tid

  • bool_int1

    描述:将bool转为int1。

    参数:boolean

    返回值类型:tinyint

  • bool_int2

    描述:将bool转为int2。

    参数:boolean

    返回值类型:smallint

  • bool_int8

    描述:将bool转为tinyint。

    参数:boolean

    返回值类型:bigint

  • bpchar_date

    描述:将字符串转为日期。

    参数:character

    返回值类型:date

  • bpchar_float4

    描述:将字符串转为float4。

    参数:character

    返回值类型:real

  • bpchar_float8

    描述:将字符串转为float8。

    参数:character

    返回值类型:double precision

  • bpchar_int4

    描述:将字符串转为int4。

    参数:character

    返回值类型:integer

Copyright © 2011-2024 www.enmotech.com All rights reserved.