Oracle及Mysql中对当前时间的格式化及计算一个月有多少天

来源:互联网 发布:hive数据导入 编辑:程序博客网 时间:2024/05/01 15:21

Oracle中:

 public String queryOracleTime(){
SQLQuery query = null;
String resultSql = "select to_char(sysdate,'yyyymmddHH24miss') from dual";
query = (SQLQuery) getSession().createSQLQuery(resultSql);
return query.list().get(0).toString();
}


Mysql中:

public String queryMySQLTime(){
SQLQuery query = null;
String resultSql = "select date_format(now(),'%Y%m%d%k%i%s');";
query = (SQLQuery) getSession().createSQLQuery(resultSql);
return query.list().get(0).toString();
}


Mysql中的时间格式 :


取得当前时间用 now() 就行。
在数据库中格式化时间 用DATE_FORMA T(date, format) .
根据格式串format 格式化日期或日期和时间值date,返回结果串。


  可用DATE_FORMAT( ) 来格式化DATE 或DATETIME 值,以便得到所希望的格式。根据format字符串格式化date值:


  %S, %s 两位数字形式的秒( 00,01, . . ., 59)

  %i 两位数字形式的分( 00,01, . . ., 59)

  %H 两位数字形式的小时,24 小时(00,01, . . ., 23)

  %h, %I 两位数字形式的小时,12 小时(01,02, . . ., 12)

  %k 数字形式的小时,24 小时(0,1, . . ., 23)

  %l 数字形式的小时,12 小时(1, 2, . . ., 12)

  %T 24 小时的时间形式(h h : m m : s s)

  %r 12 小时的时间形式(hh:mm:ss AM 或hh:mm:ss PM)

  %p AM 或P M

  %W 一周中每一天的名称( S u n d a y, Monday, . . ., Saturday)

  %a 一周中每一天名称的缩写( Sun, Mon, . . ., Sat)

  %d 两位数字表示月中的天数( 00, 01, . . ., 31)

  %e 数字形式表示月中的天数( 1, 2, . . ., 31)

 %D 英文后缀表示月中的天数( 1st, 2nd, 3rd, . . .)

  %w 以数字形式表示周中的天数( 0 = S u n d a y, 1=Monday, . . ., 6=Saturday)

  %j 以三位数字表示年中的天数( 001, 002, . . ., 366)

  % U 周(0, 1, 52),其中Sunday 为周中的第一天

  %u 周(0, 1, 52),其中Monday 为周中的第一天

  %M 月名(J a n u a r y, February, . . ., December)

  %b 缩写的月名( J a n u a r y, February, . . ., December)

  %m 两位数字表示的月份( 01, 02, . . ., 12)

  %c 数字表示的月份( 1, 2, . . ., 12)

  %Y 四位数字表示的年份

  %y 两位数字表示的年份

  %% 直接值“%”

  select date_format(日期字段,’%Y-%m-%d’) as ‘日期’ from test



计算一个月有多少天:

Oracle:

select to_number(add_months(to_date('2012-09','yyyy-fmmm'),1)-to_date('2012-09','yyyy-fmmm')) daynum from dual

Mysql:

SELECT day(LAST_DAY('2012-09-01'));


转化为小时,天,及月的整形形式:

Oracle:to_char(hps_passvehicleinfo.pass_Time, 'hh24') 

mysql:HOUR(hps_passvehicleinfo.pass_Time) as hour


Oracle:to_char(hps_passvehicleinfo.pass_Time, 'dd') 

mysql:DAY(hps_passvehicleinfo.pass_Time) as hour



Oracle:to_char(hps_passvehicleinfo.pass_Time, 'mm') 

mysql:MONTH(hps_passvehicleinfo.pass_Time) as hour










原创粉丝点击