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
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)