oracle中timestamp作为查询条件(to_char函数的使用)

SELECT * FROM COOK_BOOK cb WHERE "TO_CHAR"(CB.USE_DAY,'yyyy-mm-dd HH24') = '2018-09-29 00'

Oracle to_char函数的功能是将数值型或者日期型转化为字符型,下面就为您详细介绍Oracle to_char函数的使用,希望对您能有所帮助。

Postgres 格式化函数提供一套有效的工具用于把各种数据类型(日期/时间,int,float,numeric)转换成格式化的字符串以及反过来从格式化的字符串转换成原始的数据类型。
注意:所有格式化函数的第二个参数是用于转换的模板。

表 5-7. 格式化函数

函数 返回 描述 例子
to_char(timestamp, text) text 把 timestamp 转换成 string to_char(timestamp 'now','HH12:MI:SS')
to_char(int, text) text 把 int4/int8 转换成 string to_char(125, '999')
to_char(float, text) text 把 float4/float8 转换成 string to_char(125.8, '999D9')
to_char(numeric, text) text 把 numeric 转换成 string to_char(numeric '-125.8', '999D99S')
to_date(text, text) date 把 string 转换成 date to_date('05 Dec 2000', 'DD Mon YYYY')
to_timestamp(text, text) date 把 string 转换成 timestamp to_timestamp('05 Dec 2000', 'DD Mon YYYY')
to_number(text, text) numeric 把 string 转换成 numeric to_number('12,454.8-', '99G999D9S')

表 5-8. 用于 date/time 转换的模板

模板 描述
HH 一天的小时数 (01-12)
HH12 一天的小时数 (01-12)
HH24 一天的小时数 (00-23)
MI 分钟 (00-59)
SS 秒 (00-59)
SSSS 午夜后的秒 (0-86399)
AM or A.M. or PM or P.M. 正午标识(大写)
am or a.m. or pm or p.m. 正午标识(小写)
Y,YYY 带逗号的年(4 和更多位)
YYYY 年(4和更多位)
YYY 年的后三位
YY 年的后两位
Y 年的最后一位
BC or B.C. or AD or A.D. 年标识(大写)
bc or b.c. or ad or a.d. 年标识(小写)
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)
DD 一个月里的日子(01-31)
D 一周里的日子(1-7;SUN=1)
W 一个月里的周数
WW 一年里的周数
CC 世纪(2 位)
J Julian 日期(自公元前4712年1月1日来的日期)
Q 季度
RM 罗马数字的月份(I-XII;I=JAN)-大写
rm 罗马数字的月份(I-XII;I=JAN)-小写

所有模板都都允许使用前缀和后缀修改器。模板里总是允许使用修改器。前缀 '<tt>FX</tt>' 只是一个全局修改器。

表 5-9. 用于日期/时间模板 to_char() 的后缀

后缀 描述 例子
FM 填充模式前缀 FMMonth
TH 大写顺序数后缀 DDTH
th 小写顺序数后缀 DDTH
FX 固定模式全局选项(见下面) FX Month DD Day
SP 拼写模式(还未实现) DDSP

用法须知:

  • 如果没有使用 <tt>FX</tt> 选项,<tt>to_timestamp</tt> 和 <tt>to_date</tt> 忽略空白。<tt>FX</tt> 必须做为模板里的第一个条目声明。
  • 反斜杠("")必须用做双反斜杠("\"),例如 '\HH\MI\SS'。
  • 双引号('"')之间的字串被忽略并且不被分析。如果你想向输出写双引号,你必须在双引号前面放置一个双反斜杠(<tt>'\'),例如 '\"YYYY Month\"'</tt>。
  • <tt>to_char</tt> 支持不带前导双引号('"')的文本,但是在双引号之间的任何字串会被迅速处理并且还保证不会被当作模板关键字解释(例如:<tt>'"Hello Year: "YYYY'</tt>)。

表 5-10. 用于 to_char(<tt>numeric</tt>) 的模板

模板 描述
9 带有指定位数的值
0 前导零的值
. (句点) 小数
, (逗号) 分组(千)分隔符
PR 尖括号内负值
S 带负号的负值(使用本地化)
L 货币符号(使用本地化)
D 小数点(使用本地化)
G 分组分隔符(使用本地化)
MI 在指明的位置的负号(如果数字 < 0)
PL 在指明的位置的正号(如果数字 > 0)
SG 在指明的位置的正/负号
RN 罗马数字(输入在 1 和 3999 之间)
TH or th 转换成序数
V 移动 <tt>n</tt> 位(小数)(参阅注解)
EEEE 科学记数。现在不支持。

用法须知:

  • 使用 'SG','PL' 或 'MI' 的带符号字并不附着在数字上面;例如,to_char(-12, 'S9999') 生成 <tt>' -12'</tt>,而 to_char(-12, 'MI9999') 生成 <tt>'- 12'</tt>。Oracle 里的实现不允许在 <tt>9</tt> 前面使用 <tt>MI</tt>,而是要求 <tt>9</tt> 在 <tt>MI</tt>前面。
  • <tt>PL</tt>,<tt>SG</tt>,和 <tt>TH</tt> 是 Postgres 扩展。
  • <tt>9</tt> 表明一个与在 <tt>9</tt> 字串里面的一样的数字位数。如果没有可用的数字,那么使用一个空白(空格)。
  • <tt>TH</tt> 不转换小于零的值,也不转换小数。<tt>TH</tt> 是一个 Postgres 扩展。
  • <tt>V</tt> 方便地把输入值乘以 <tt>10^n</tt>,这里 <tt>n</tt> 是跟在 <tt>V</tt> 后面的数字。<tt>to_char</tt> 不支持把 <tt>V</tt> 与一个小数点绑在一起使用(例如. "99.9V99" 是不允许的)。

表 5-11. <tt>to_char</tt> 例子

输入 输出
to_char(now(),'Day, HH12:MI:SS') <tt>'Tuesday , 05:39:18'</tt>
to_char(now(),'FMDay, HH12:MI:SS') <tt>'Tuesday, 05:39:18'</tt>
to_char(-0.1,'99.99') <tt>' -.10'</tt>
to_char(-0.1,'FM9.99') <tt>'-.1'</tt>
to_char(0.1,'0.9') <tt>' 0.1'</tt>
to_char(12,'9990999.9') <tt>' 0012.0'</tt>
to_char(12,'FM9990999.9') <tt>'0012'</tt>
to_char(485,'999') <tt>' 485'</tt>
to_char(-485,'999') <tt>'-485'</tt>
to_char(485,'9 9 9') <tt>' 4 8 5'</tt>
to_char(1485,'9,999') <tt>' 1,485'</tt>
to_char(1485,'9G999') <tt>' 1 485'</tt>
to_char(148.5,'999.999') <tt>' 148.500'</tt>
to_char(148.5,'999D999') <tt>' 148,500'</tt>
to_char(3148.5,'9G999D999') <tt>' 3 148,500'</tt>
to_char(-485,'999S') <tt>'485-'</tt>
to_char(-485,'999MI') <tt>'485-'</tt>
to_char(485,'999MI') <tt>'485'</tt>
to_char(485,'PL999') <tt>'+485'</tt>
to_char(485,'SG999') <tt>'+485'</tt>
to_char(-485,'SG999') <tt>'-485'</tt>
to_char(-485,'9SG99') <tt>'4-85'</tt>
to_char(-485,'999PR') <tt>'<485>'</tt>
to_char(485,'L999') <tt>'DM 485</tt>
to_char(485,'RN') <tt>' CDLXXXV'</tt>
to_char(485,'FMRN') <tt>'CDLXXXV'</tt>
to_char(5.2,'FMRN') <tt>V</tt>
to_char(482,'999th') <tt>' 482nd'</tt>
to_char(485, '"Good number:"999') <tt>'Good number: 485'</tt>
to_char(485.8,'"Pre-decimal:"999" Post-decimal:" .999') <tt>'Pre-decimal: 485 Post-decimal: .800'</tt>
to_char(12,'99V999') <tt>' 12000'</tt>
to_char(12.4,'99V999') <tt>' 12400'</tt>
to_char(12.45, '99V9') <tt>' 125'</tt>

Oracle to_char函数最简单的应用:

/1.0123--->'1.0123'/
Select TO_CHAR(1.0123) FROM DUAL
/123--->'123'/
Select TO_CHAR(123) FROM DUAL

接下来再看看下面:

/*0.123 ---> '.123' */
SELEC TO_CHAR(0.123) FROM DUAL

上面的结果 '.123' 在大多数情况下都不是我们想要的结果,我们想要的应该是 '0.123'。

我们来看一下to_char函数的具体用法:

TO_CHAR ( n [, fmt [, 'nlsparam']] )

Oracle to_char函数将NUMBER类型的n按数值格式fmt转换成VARCHAR2类型的值。'nlsparams'指定由数值格式的元素返回的字符,包括:

.小数点字符
.组分隔符
.本地钱币符号
.国际钱币符号

变元的形式为:

'NLS_NUMERIC_CHARACTERS="dg" NLS_CURRENCY="tcxt" NLS_ISO_CURRENCY=territory'

其中d为小数点字符,g为组分隔符。

例 :TO_CHAR (17145,'L099G999','NLS_NUMERIC_CHARACTERS=".," NLS_CURRENCY="NUD"')=NUD017,145
通过上面的了解,再查看fmt的一些格式,我们可以用以下表达式得到'0.123'的值:

/*0.123 ---> ' 0.123' /
Select TO_CHAR(0.123,'0.999') FROM DUAL
/
100.12 ---> '######' /
Select TO_CHAR(100.12,'0.999') FROM DUAL
/
1.12 ---> ' 1.120' */
Select TO_CHAR(1.12,'0.999') FROM DUAL
' 0.123'是出来了,可是前面又多了一个空格。

对于 100.12 的值却是######,以及'1.12'的值变成了 '1.120'。

我们重新确定一个新的需求:

1、去空格
2、小数点最多4位,最少保留2位。

1--->'1.00';1.1--->'1.00';1.12-->'1.12';1.1234--->'1.1234';

1.12345--->'1.1235'

最终实现如下:

/*
FM :除空格
9999999.0099:允许小数点左边最大正数为7位,小数点右边最少2位,最多4位,且在第5位进行四舍五入
*/
Select TO_CHAR(123.0233,'FM9999999.0099') FROM tablename

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336

推荐阅读更多精彩内容