本篇内容主要讲解“数据库中TO_CHAR格式转换的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“数据库中TO_CHAR格式转换的方法是什么”吧!

我的经理叫我写一个函数,这个函数接受一个正整数并返回相应的序数(比如,2->2nd, 145->145th), 这个序数是一个字符串。这个函数只接受1和50,000之间的整数。

下列的哪些选项实现了函数plch_n_to_nth, 从而使得它满足上述需求,在下列块被执行之后:

BEGINDBMS_OUTPUT.put_line(plch_n_to_nth(1));DBMS_OUTPUT.put_line(plch_n_to_nth(8));DBMS_OUTPUT.put_line(plch_n_to_nth(256));DBMS_OUTPUT.put_line(plch_n_to_nth(25763));END;/

我能见到如下输出:

1st8th256th25763rd

(A)

CREATEORREPLACEFUNCTIONplch_n_to_nth(n_inININTEGER)RETURNVARCHAR2ISBEGINRETURNTO_CHAR(n_in,'9999th');END;/

SQL>BEGIN2DBMS_OUTPUT.put_line(plch_n_to_nth(1));3DBMS_OUTPUT.put_line(plch_n_to_nth(8));4DBMS_OUTPUT.put_line(plch_n_to_nth(256));5DBMS_OUTPUT.put_line(plch_n_to_nth(25763));6END;7/BEGINDBMS_OUTPUT.put_line(plch_n_to_nth(1));DBMS_OUTPUT.put_line(plch_n_to_nth(8));DBMS_OUTPUT.put_line(plch_n_to_nth(256));DBMS_OUTPUT.put_line(plch_n_to_nth(25763));END;ORA-01481:无效的数字格式模型ORA-06512:在"YOGA.PLCH_N_TO_NTH",line5ORA-06512:在line2SQL>

(B)

CREATEORREPLACEFUNCTIONplch_n_to_nth(n_inININTEGER)RETURNVARCHAR2ISBEGINRETURNLOWER(TO_CHAR(TO_DATE('1-1-'||n_in,'dd-mm-yyyy'),'FMYYYYth'));END;/

SQL>BEGIN2DBMS_OUTPUT.put_line(plch_n_to_nth(1));3DBMS_OUTPUT.put_line(plch_n_to_nth(8));4DBMS_OUTPUT.put_line(plch_n_to_nth(256));5DBMS_OUTPUT.put_line(plch_n_to_nth(25763));6END;7/1st8th256thBEGINDBMS_OUTPUT.put_line(plch_n_to_nth(1));DBMS_OUTPUT.put_line(plch_n_to_nth(8));DBMS_OUTPUT.put_line(plch_n_to_nth(256));DBMS_OUTPUT.put_line(plch_n_to_nth(25763));END;ORA-01830:日期格式图片在转换整个输入字符串之前结束ORA-06512:在"YOGA.PLCH_N_TO_NTH",line5ORA-06512:在line5SQL>

(C)

CREATEORREPLACEFUNCTIONplch_n_to_nth(n_inININTEGER)RETURNVARCHAR2ISBEGINRETURNLOWER(TO_CHAR(TO_DATE('1-1-2011'||n_in,'dd-mm-yyyySSSSS'),'FMSSSSSth'));END;/

SQL>BEGIN2DBMS_OUTPUT.put_line(plch_n_to_nth(1));3DBMS_OUTPUT.put_line(plch_n_to_nth(8));4DBMS_OUTPUT.put_line(plch_n_to_nth(256));5DBMS_OUTPUT.put_line(plch_n_to_nth(25763));6END;7/1st8th256th25763rdPL/SQLproceduresuccessfullycompletedSQL>

(D)

CREATEORREPLACEFUNCTIONplch_n_to_nth(n_inININTEGER)RETURNVARCHAR2ISc_last_digitCONSTANTPLS_INTEGER:=MOD(n_in,10);c_tens_digitCONSTANTCHAR(1):=SUBSTR('0'||TO_CHAR(n_in),-2,1);BEGINRETURNTO_CHAR(n_in)||CASEWHENc_tens_digit='1'THEN'th'WHENc_last_digit=1THEN'st'WHENc_last_digit=2THEN'nd'WHENc_last_digit=3THEN'rd'ELSE'th'END;ENDplch_n_to_nth;/

SQL>BEGIN2DBMS_OUTPUT.put_line(plch_n_to_nth(1));3DBMS_OUTPUT.put_line(plch_n_to_nth(8));4DBMS_OUTPUT.put_line(plch_n_to_nth(256));5DBMS_OUTPUT.put_line(plch_n_to_nth(25763));6END;7/1st8th256th25763rdPL/SQLproceduresuccessfullycompletedSQL>

CD.(A)你不能在TO_CHAR(NUMBER)中使用TH格式,只能在TO_CHAR(datetime)中使用。(B)差点就对了,这个答案在年份使用了th格式,但ORACLE不支持高达50,000的年份,会出现如下错误:ORA-01830:dateformatpictureendsbeforeconvertingentireinputstring(C)这个正确使用了TO_CHAR(datetime)的th格式,一天中有86400秒,足够使用。(D)这个自定义函数正确实现了转换规则。

到此,相信大家对“数据库中TO_CHAR格式转换的方法是什么”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!