暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

华为GaussDB T 类型转换函数

墨天轮 2019-10-12
1798

类型转换函数

ASCII

语法:

ASCII(str)

功能:返回字符串str首个字符对应的ASCII码。

入参是字符串或单个字符,需要使用单引号('')括起来;返回值是ASCII码。

示例:

返回字符串helloword首个字符(h)对应的ASCII码。
SELECT ASCII('helloword') FROM SYS_DUMMY; ASCII('HELLOWORD') -------------------- 104 1 rows fetched.

CAST

语法:

CAST(expr as datatype)

功能:将列名/值转换为指定的数据类型datatype。

表达式可以转换为与自身相同的类型。

使用CAST函数进行数据类型转换时,以下情况可以转换,否则报错:

  • 两个表达式可隐式转换。
  • 必须显式转换数据类型。

示例:

将字符串'10'转换为int类型值。
SELECT CAST('10' AS INT) FROM SYS_DUMMY; CAST('10' AS INT) ----------------- 10 1 rows fetched.

CHAR

语法:

CHAR(n)

功能:返回ASCII码为n的字符。n支持范围为[0,127]。

入参是可转成数值型表达式。返回值是ASCII码为n的字符。

示例:

返回ASCII码为67的字符。
SELECT CHAR(67) FROM SYS_DUMMY; CHAR(67) -------- C 1 rows fetched.

CHR

语法:

CHR(n)

功能:返回ASCII码为n的字符。n支持范围为[0,127]。

入参是可转成数值型表达式。返回值是ASCII码为n的字符。

示例:

返回ASCII码为97的字符。
SELECT CHR(97) FROM SYS_DUMMY; CHR(97) ------- a 1 rows fetched.

CONVERT

语法:

CONVERT(expr,data_type)

功能:将expr转换成data_type类型。

data_type取值范围是除了CLOB,BLOB,IMAGE以外的所有数据类型(参考数据类型)。

示例:

将字符串转换为时间类型。
SELECT CONVERT('2018-06-28 13:14:15', timestamp) as datetime FROM SYS_DUMMY; DATETIME --------------------------------------------------------------- 2018-06-28 13:14:15.000000 1 rows fetched.

DECODE

语法:

DECODE(expr,{search,result} [,...] [default])

功能:

  • 将expr与多个search进行比较,如果expr等于search,则返回对应result。
  • 如果未找到匹配项,则返回default。
  • 如果未指定default,则返回空值。
  • 可以指定多个search及对应result,用逗号(,)分隔。
  • 入参支持的数据类型是INTEGER UNSIGNED、INT、BIGINT、REAL、STRING、NUMBER、DATE、TIMESTAMP、BINARY。
  • 返回值是STRING。

示例:

解码表staffS_xian的staff_ID值。
--删除同名表staffS_xian。 DROP TABLE IF EXISTS staffS_xian;
--创建表staffS_xian。 CREATE TABLE staffS_xian ( staff_ID NUMBER(6) not null, NAME VARCHAR2(20), EMAIL VARCHAR2(25), PHONE_NUMBER VARCHAR2(20), HIRE_DATE DATE, employment_ID VARCHAR2(10), SALARY NUMBER(8,2), MANAGER_ID NUMBER(6), section_ID NUMBER(4) );
--向表staffS_xian中插入记录1。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (198, '王莹', 'wangying@126.com', '18095605632', to_date('21-06-1999', 'dd-mm-yyyy'), 'SH_CLERK', 2600.00, 124, 50); --向表staffS_xian中插入记录2。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (199, '何开平', 'hekaipng02@126.com', '18095605532', to_date('13-01-2000', 'dd-mm-yyyy'), 'SH_CLERK', 2600.00, 124, 50); --向表staffS_xian中插入记录3。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (200, '李瑞', 'lirui03@126.com', '18095565632', to_date('17-09-1987', 'dd-mm-yyyy'), 'AD_ASST', 4400.00, 101, 10);
--解码值staff_ID。如果staff_ID为198,则函数返回“A组”;如果staff_ID为199,则返回“B组”。如果staff_ID不是198、199,则函数返回“unknown”。 SELECT staff_ID, DECODE (staff_ID, 198, 'A组', 199, 'B组', 'unknown') "GROUP" FROM staffS_xian WHERE staff_ID < 201 ORDER BY staff_ID; STAFF_ID GROUP ---------------------------------------- ------- 198 A组 199 B组 200 unknown 3 rows fetched.

IF

语法:

IF(cond,exp1,exp2)

功能:计算条件cond,如果条件为真,则返回exp1,否则返回exp2。

示例:

返回员工编号和工资列表,工资如果为NULL则返回secret。
--删除同名表staffS_xian。 DROP TABLE IF EXISTS staffS_xian;
--创建表staffS_xian。 CREATE TABLE staffS_xian ( staff_ID NUMBER(6) not null, NAME VARCHAR2(20), EMAIL VARCHAR2(25), PHONE_NUMBER VARCHAR2(20), HIRE_DATE DATE, employment_ID VARCHAR2(10), SALARY NUMBER(8,2), MANAGER_ID NUMBER(6), section_ID NUMBER(4) );
--向表staffS_xian中插入记录1。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (198, '王莹', 'wangying@126.com', '18095605632', to_date('21-06-1999', 'dd-mm-yyyy'), 'SH_CLERK', NULL, 124, 50); --向表staffS_xian中插入记录2。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (199, '何开平', 'hekaipng02@126.com', '18095605532', to_date('13-01-2000', 'dd-mm-yyyy'), 'SH_CLERK', 2600.00, 124, 50); --向表staffS_xian中插入记录3。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (200, '李瑞', 'lirui03@126.com', '18095565632', to_date('17-09-1987', 'dd-mm-yyyy'), 'AD_ASST', 4400.00, 101, 10); --向表staffS_xian中插入记录4。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (206, '李锐云', 'liruiyun03@126.com', '18095565892', to_date('17-09-1988', 'dd-mm-yyyy'), 'AD_ASST', 3900.00, 101, 10);
--返回员工编号和工资列表,工资如果为NULL则返回secret。 SELECT staff_ID, IF(SALARY < 4000, SALARY, 'secret') "SALARY" FROM staffS_xian WHERE staff_ID IS NOT NULL ORDER BY staff_ID; STAFF_ID SALARY ---------------------------------------- ---------------------------------------------------- 198 secret 199 2600 200 secret 206 3900 4 rows fetched.

IFNULL

语法:

IFNULL(expr1, expr2)

功能:

  • 如果expr1不为NULL,则返回expr1。
  • 如果expr1等于NULL,则返回expr2。

示例:

返回员工编号和工资列表,工资如果为NULL则返回unknown。
--删除同名表staffS_xian。 DROP TABLE IF EXISTS staffS_xian;
--创建表staffS_xian。 CREATE TABLE staffS_xian ( staff_ID NUMBER(6) not null, NAME VARCHAR2(20), EMAIL VARCHAR2(25), PHONE_NUMBER VARCHAR2(20), HIRE_DATE DATE, employment_ID VARCHAR2(10), SALARY NUMBER(8,2), MANAGER_ID NUMBER(6), section_ID NUMBER(4) );
--向表staffS_xian中插入记录1。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (198, '王莹', 'wangying@126.com', '18095605632', to_date('21-06-1999', 'dd-mm-yyyy'), 'SH_CLERK', NULL, 124, 50); --向表staffS_xian中插入记录2。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (199, '何开平', 'hekaipng02@126.com', '18095605532', to_date('13-01-2000', 'dd-mm-yyyy'), 'SH_CLERK', 2600.00, 124, 50); --向表staffS_xian中插入记录3。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (200, '李瑞', 'lirui03@126.com', '18095565632', to_date('17-09-1987', 'dd-mm-yyyy'), 'AD_ASST', 4400.00, 101, 10);
--返回员工编号和工资列表,工资如果为NULL则返回unknown。 SELECT staff_ID, IFNULL(SALARY, 'unknown') "SALARY" FROM staffS_xian WHERE staff_ID IS NOT NULL ORDER BY staff_ID; STAFF_ID SALARY ---------------------------------------- ---------------------------------------------------- 198 unknown 199 2600 200 4400 3 rows fetched.

NULLIF

语法:

NULLIF(expr1, expr2)

功能:

  • 如果expr1等于expr2,则返回NULL。
  • 如果expr1不等于expr2, 则返回expr1。

说明

  • expr1不能为NULL,否则校验报错。
  • expr1和expr2应该为相同数据类型,否则校验报错。
  • 不支持两个参数同为clob类型或同为blob类型。

示例:

返回员工编号和工资列表,若工资不为2600.00则显示实际工资,若工资为2600.00则显示空值。
--删除同名表staffS_xian。 DROP TABLE IF EXISTS staffS_xian;
--创建表staffS_xian。 CREATE TABLE staffS_xian ( staff_ID NUMBER(6) not null, NAME VARCHAR2(20), EMAIL VARCHAR2(25), PHONE_NUMBER VARCHAR2(20), HIRE_DATE DATE, employment_ID VARCHAR2(10), SALARY NUMBER(8,2), MANAGER_ID NUMBER(6), section_ID NUMBER(4) );
--向表staffS_xian中插入记录1。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (198, '王莹', 'wangying@126.com', '18095605632', to_date('21-06-1999', 'dd-mm-yyyy'), 'SH_CLERK', 1000.15, 124, 50); --向表staffS_xian中插入记录2。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (199, '何开平', 'hekaipng02@126.com', '18095605532', to_date('13-01-2000', 'dd-mm-yyyy'), 'SH_CLERK', 2600.00, 124, 50); --向表staffS_xian中插入记录3。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (200, '李瑞', 'lirui03@126.com', '18095565632', to_date('17-09-1987', 'dd-mm-yyyy'), 'AD_ASST', 4400.00, 101, 10);
--返回员工编号和工资列表,若工资不为2600.00则显示实际工资,若工资为2600.00则显示空值。 SELECT staff_ID, NULLIF(SALARY, 2600.00) "SALARY" FROM staffX_xian WHERE staff_ID IS NOT NULL ORDER BY staff_ID; STAFF_ID SALARY ---------------------------------------- ---------------------------------------- 198 1000.15 199 200 4400 3 rows fetched.

NVL

语法:

NVL(expr1, expr2)

功能:

  • 如果expr1不为NULL,则返回expr1。
  • 如果expr1等于NULL,则返回expr2。

示例:

返回员工编号和工资列表,工资如果为NULL则返回0。
--删除同名表staffS_xian。 DROP TABLE IF EXISTS staffS_xian;
--创建表staffS_xian。 CREATE TABLE staffS_xian ( staff_ID NUMBER(6) not null, NAME VARCHAR2(20), EMAIL VARCHAR2(25), PHONE_NUMBER VARCHAR2(20), HIRE_DATE DATE, employment_ID VARCHAR2(10), SALARY NUMBER(8,2), MANAGER_ID NUMBER(6), section_ID NUMBER(4) );
--向表staffS_xian中插入记录1。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (198, '王莹', 'wangying@126.com', '18095605632', to_date('21-06-1999', 'dd-mm-yyyy'), 'SH_CLERK', NULL, 124, 50); --向表staffS_xian中插入记录2。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (199, '何开平', 'hekaipng02@126.com', '18095605532', to_date('13-01-2000', 'dd-mm-yyyy'), 'SH_CLERK', 2600.00, 124, 50); --向表staffS_xian中插入记录3。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (200, '李瑞', 'lirui03@126.com', '18095565632', to_date('17-09-1987', 'dd-mm-yyyy'), 'AD_ASST', 4400.00, 101, 10);
--返回员工编号和工资列表,工资如果为NULL则返回0。 SELECT staff_ID, NVL(SALARY,0) "SALARY" FROM staffS_xian WHERE staff_ID IS NOT NULL ORDER BY staff_ID; STAFF_ID SALARY ---------------------------------------- ---------------------------------------- 198 0 199 2600 200 4400 3 rows fetched.

NVL2

语法:

NVL2(expr1,expr2,expr3)

功能:

  • 如果expr1值不为NULL, 则返回expr2的值。
  • 如果expr1等于NULL,则返回expr3的值。

示例:

返回员工编号和工资列表,工资如果为NULL则返回0,不为NULL则返回1。
--删除同名表staffS_xian。 DROP TABLE IF EXISTS staffS_xian;
--创建表staffS_xian。 CREATE TABLE staffS_xian ( staff_ID NUMBER(6) not null, NAME VARCHAR2(20), EMAIL VARCHAR2(25), PHONE_NUMBER VARCHAR2(20), HIRE_DATE DATE, employment_ID VARCHAR2(10), SALARY NUMBER(8,2), MANAGER_ID NUMBER(6), section_ID NUMBER(4) );
--向表staffS_xian中插入记录1。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (198, '王莹', 'wangying@126.com', '18095605632', to_date('21-06-1999', 'dd-mm-yyyy'), 'SH_CLERK', NULL, 124, 50); --向表staffS_xian中插入记录2。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (199, '何开平', 'hekaipng02@126.com', '18095605532', to_date('13-01-2000', 'dd-mm-yyyy'), 'SH_CLERK', 2600.00, 124, 50); --向表staffS_xian中插入记录3。 INSERT INTO staffS_xian (staff_ID, NAME, EMAIL, PHONE_NUMBER, HIRE_DATE, employment_ID, SALARY, MANAGER_ID, section_ID) values (200, '李瑞', 'lirui03@126.com', '18095565632', to_date('17-09-1987', 'dd-mm-yyyy'), 'AD_ASST', 4400.00, 101, 10);
--返回员工编号和工资列表,工资如果为NULL则返回0,不为NULL则返回1。 SELECT staff_ID, NVL2(SALARY,1,0) "SALARY" FROM staffS_xian WHERE staff_ID IS NOT NULL ORDER BY staff_ID; STAFF_ID SALARY ---------------------------------------- ------------ 198 0 199 1 200 1 3 rows fetched.

TO_CHAR

语法:

TO_CHAR(expr[,fmt])

功能:将expr转换成字符串。

  • 入参是可转成string的表达式。
  • 返回值是STRING。
  • fmt为日期类型的格式控制符,例如,yyyy/mm/dd/hh/hh12/hh24/mi/ss/ff3等,(详情请参见日期类型说明)。如果没有指定format,则默认使用当前SESSION的时间格式。

当前SESSION的时间格式可以通过如下命令设置:

--通过NLS_DATE_FORMATDATE设置DATE类型的时间格式。 ALTER SESSION SET NLS_DATE_FORMAT='format'; --通过NLS_TIMESTAMP_FORMAT设置TIMESTAMP类型的时间格式。 ALTER SESSION SET NLS_TIMESTAMP_FORMAT='format';

说明:

该函数当前仅支持对日期类型(date, timestamp)指定格式控制符。

示例:

  • 指定格式控制符,返回当前系统时间。
    SELECT to_char(sysdate, 'MON-YY-DD HH:MM:SS AM') FROM SYS_DUMMY; TO_CHAR(SYSDATE, 'MON-YY-DD HH ------------------------------- JAN-18-07 05:01:15 AM 1 rows fetched.
  • 设置当前SESSION的时间格式,并返回当前连接的系统时间。
    --通过NLS_DATE_FORMATDATE设置时间格式。 ALTER SESSION SET NLS_DATE_FORMAT='YYYYMMDD HH24:MI:SS';
    --查询当前系统时间。 SELECT TO_CHAR(sysdate) FROM SYS_DUMMY; TO_CHAR(SYSDATE) ------------------------------------------------ 20181207 15:12:24 1 rows fetched.
  • 将“56698”转换成字符串。
    SELECT TO_CHAR('56698') FROM SYS_DUMMY; TO_CHAR('56698') ---------------- 56698 1 rows fetched.

TO_CLOB

语法:

TO_CLOB(str)

功能:将入参转换为CLOB类型,str为待转换的类型参数。

示例:

将字段comment的数据转换为CLOB类型。
--删除表employee。 DROP TABLE IF EXISTS employee_branch_nanjing;
--创建表employee。 CREATE TABLE employee_branch_nanjing(employee_id INT NOT NULL,first_name VARCHAR(10),last_name VARCHAR(10), hire_date DATETIME,comment VARCHAR(1012));
--插入记录1。 INSERT INTO employee_branch_nanjing(employee_id,first_name,last_name,hire_date,comment) VALUES(1001,'Alice','BROWN','2017-06-20 12:00:00','excellent staff of 2018,bonus 5000¥'); --插入记录2。 INSERT INTO employee_branch_nanjing(employee_id,first_name,last_name,hire_date,comment) VALUES(1002,'BOB','Smith','2017-10-20 12:00:00','excellent manager of 2018,bonus 2000¥'); --插入记录3。 INSERT INTO employee_branch_nanjing(employee_id,first_name,last_name,hire_date,comment) VALUES(1003,'ALAN','Jones','2017-05-10 12:00:00',''); --提交事务。 COMMIT;
--将字段comment的数据转换为CLOB类型。 UPDATE employee_branch_nanjing SET comment=TO_CLOB(comment); 3 rows affected.

TO_DATE

语法:

TO_DATE(expr[,fmt])

功能:将expr转换成日期类型。

  • fmt为转换格式,支持如下:yyyy/mm/dd/hh/hh12/hh24/mi/ss/ff3等。
  • 入参是可转成DATE类型的字符串表达式或者数值类型(隐式转换)。
  • 返回值是DATE。

示例:

将字符串转换为日期类型。
SELECT TO_DATE('2018-06-28 13:14:15', 'YYYY-MM-DD HH24:MI:SS:FF') FROM SYS_DUMMY; TO_DATE('2018-06-28 13:14:15', 'YYYY-MM-DD HH24:MI:SS:FF') ---------------------------------------------------------- 2018-06-28 13:14:15 1 rows fetched.

TO_NUMBER

语法:

TO_NUMBER(n[, fmt])

功能:将n转换为number类型。

入参n是可转成数值型的表达式或字符串。fmt参数可选,表示n的转换格式, 不设置时,默认转换为十进制。当前fmt支持两种固定格式,分别为:

  • X: 对n按16进制串进行转换, 在该格式中n只能包含16进制字符,0~9,A~F, a~f。
    • 以XX这种格式转换时,X的个数必须大于等于前面的字符个数。
    • 以0X这种格式转换时,n只能为0或正整数。
  • 000.00:对n按10进制格式转换,小数点前面的数字的个数表示整数的个数,若n中整数个数超过格式中的整数个数将会报错;fmt中小数点后面的数字个数表示转换后保留的小数位数。

返回值是number。

示例1:

将123E500转换为number类型。

SELECT TO_NUMBER('123E500', 'XXXXXXX') from SYS_DUMMY; TO_NUMBER('123E500', 'XXXXXXX') ---------------------------------------- 19129600 1 rows fetched.

示例2:

将123.500转换为number类型。

SELECT TO_NUMBER('123.500', '000.0000') from SYS_DUMMY; TO_NUMBER('123.500', '000.0000') ---------------------------------------- 123.5 1 rows fetched.

示例3:

将00FFFFFF转换为number类型。

SELECT TO_NUMBER('00FFFFFF', '0000000X') from SYS_DUMMY; ---------------------------------------- 16777215 1 rows fetched.

TO_TIMESTAMP

语法:

TO_TIMESTAMP(expr[,fmt])

功能:将expr转换成时间类型。

  • fmt为转换格式,支持如下:yyyy/mm/dd/hh/hh12/hh24/mi/ss/ff3等。
  • 入参是可转成TIMESTAMP类型的字符串表达式。
  • 返回值是TIMESTAMP。

示例:

将字符串转换为时间类型。
SELECT TO_TIMESTAMP('2018-06-28 13:14:15', 'YYYY-MM-DD HH24:MI:SS:FF') FROM SYS_DUMMY; TO_TIMESTAMP('2018-06-28 13:14:15', 'YYYY-MM-DD HH24:MI:SS:FF') --------------------------------------------------------------- 2018-06-28 13:14:15.000000 1 rows fetched.

UNHEX

语法:

UNHEX(expr1)

功能:expr1为十六进制字符串,将十六进制字符串转化为byte字节表示的字符。

示例:

将十六进制字符串(746869732069732061207465737420737472)转化为byte字节表示的字符。
SELECT UNHEX('746869732069732061207465737420737472') FROM SYS_DUMMY; UNHEX('746869732069732061207465737420737472') ---------------------------------------------------------------- this is a test str 1 rows fetched.
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论