Oracle数据库to_date()和to_char()的相关

Oracle数据库to_date()和to_char()的相关,第1张

select from T_A a where abegintime=to_date('2013-1-1','yyyy-mm-dd');

select from T_A a where to_char(abegintime,'yyyy-mm-dd')='2013-1-1';

查询结果是一样的

区别在于 查询的 处理步骤不一样

select from T_A a where abegintime=to_date('2013-1-1','yyyy-mm-dd');

是先把 '2013-1-1' 这个字符串, 转换为日期格式, 然后去和数据库里面做比较

如果有 1000 行数据, 那么 *** 作就是

1次 字符转换为 日期, 1000 次日期比较。

select from T_A a where to_char(abegintime,'yyyy-mm-dd')='2013-1-1';

是把数据库里面的每一行的 begintime, 转换为 字符格式, 然后去和数据库里面做比较。

如果有 1000 行数据, 那么 *** 作就是

1000次 日期转换为字符, 1000 次字符串比较。

MySQL 自己不带有 to_char 这个函数的。你要模仿 Oracle, 写一个 MySQL 的 TO_CHAR 函数这个恐怕有点麻烦。因为 Oracle 的 TO_CHAR 是可以把 日期型的, 数值型的, 转换为 字符类型。你这个MySQL 下的 to_char , 只要转换日期呢 还是转换 数字

问题解决了

给分我的体会;

不要用to_date(),to_char()函数,这两个函数只用於下列情况;

select

to_date(字段)

from

;

insert

字段

values(

to_date(),)往数据库里插日期时用

FormatDatetime('yyyy/mm/dd

hh:sss',

);取出日期时用ASDateTime转化为数字比较时再逆用

FormatDatetime('yyyy/mm/dd

hh:sss',

);

就不会出错了

用Round() + Cast()就可以:

Select bunit_name ,aamount1,aamount2,aamount3,aamount ,

cast(Round((aRate1 100),2) as varchar(13))+'%' Rate1,

cast(Round((aRate2 100),2) as varchar(13))+'%' Rate2,

cast(Round((aRate3 100),2) as varchar(13)),

cast((Round((aRate 100),2) as varchar(13)) +'%' Rate

From rv_tmp_report_sideways a,rv_unit b Where aunit_id = bunit_id

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/12163399.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-21
下一篇 2023-05-21

发表评论

登录后才能评论

评论列表(0条)

保存