字符串 与 java.sql.Timestamp转换

本文介绍了一个实用的日期时间转换工具类,包括字符串与日期、时间戳之间的相互转换方法。通过这些方法,可以轻松地实现不同格式日期时间的转换,适用于多种应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package test;

import java.sql.Timestamp;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * 时间戳与字符串转换
 * @author Administrator
 *
 */
public class DateUtil {

 /**
  * 默认日期格式
  */
 private static final String DEFAULT_FORMAT = "yyyy-MM-dd HH:mm:ss.SSS";//Timestamp format must be yyyy-mm-dd hh:mm:ss[.fffffffff]

 /**
  * 默认构造函数
  */
 private DateUtil() {
 }

 /**
  * 字符串转换成日期 如果转换格式为空,则利用默认格式进行转换操作
  * @param str 字符串
  * @param format 日期格式
  * @return 日期
  * @throws java.text.ParseException
  */
 public static Date str2Date(String str, String format){
  if (null == str || "".equals(str)) {
   return null;
  }
  // 如果没有指定字符串转换的格式,则用默认格式进行转换
  if (null == format || "".equals(format)) {
   format = DEFAULT_FORMAT;
  }
  SimpleDateFormat sdf = new SimpleDateFormat(format);
  Date date = null;
   try {
    date = sdf.parse(str);
    return date;
   } catch (ParseException e) {
    e.printStackTrace();
   }
  return null;
 }

 /** 日期转换为字符串
  * @param date 日期
  * @param format 日期格式
  * @return 字符串
  */
 public static String date2Str(Date date, String format) {
  if (null == date) {
   return null;
  }
  SimpleDateFormat sdf = new SimpleDateFormat(format);
  return sdf.format(date);
 }

 /**
  * 时间戳转换为字符串
  * @param time
  * @return
  */
 public static String timestamp2Str(Timestamp time) {
  Date date = null;
  if(null != time){
   date = new Date(time.getTime());
  }
  return date2Str(date, DEFAULT_FORMAT);
 }

 /** 字符串转换时间戳
  * @param str
  * @return
  */
 public static Timestamp str2Timestamp(String str) {
  Date date = str2Date(str, DEFAULT_FORMAT);
  return new Timestamp(date.getTime());
 }
 
 public static void main(String[] args) throws Exception {
  String tm = "2011-01-01 10:00:00.123";
  Timestamp tstamp = str2Timestamp(tm);
  System.out.println(tstamp);
  System.out.println(timestamp2Str(null));
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值