java.util.Date 与 java.sql.Date互转 及 字符串转换为日期时间格式

合集下载

JAVA字符串转日期或日期转字符串

JAVA字符串转日期或日期转字符串

JAVA字符串转日期或日期转字符串(转)2010-08-16 16:34:03| 分类: |字号订阅JAVA字符串转日期或日期转字符串(转)文章中,用的API是SimpleDateFormat,它是属于,所以请记得import进来!用法: SimpleDateFormat sdf = new SimpleDateFormat( " yyyy-MM-dd HH:mm:ss " );这一行最重要,它确立了转换的格式,yyyy是完整的公元年,MM是月份,dd是日期,至于HH:mm:ss就不需要我再解释了吧!PS:为什么有的格式大写,有的格式小写,那是怕避免混淆,例如MM是月份,mm是分;HH是24小时制,而hh是12小时制。

1.字符串转日期2008-07-10 19:20:00 要把它转成日期,可以用 Date date = sdf.parse( " 2008-07-10 19:20:00 " );2.日期转字符串假如把今天的日期转成字符串可用 String str = sdf.format(new Date());这个字符串内容的格式类似2008-07-10 19:20:00。

透过这个API我们便可以随心所欲的将日期转成我们想要的字符串格式,例如希望将日期输出成2008年7月10日,我们可以这么写:SimpleDateFormat sdf = new SimpleDateFormat( " yyyy 年MM月dd日 " );String str = sdf.format(new Date());str便会依照我们设定的格式输出了。

附编写好的一个简单实例:import ;import ;import ;public class ConvertDemo {/*** 日期转换成字符串* @param date* @return str*/public static String DateToStr(Date date) {SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String str = format.format(date);return str;}/*** 字符串转换成日期* @param str* @return date*/public static Date StrToDate(String str) {SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");Date date = null;try {date = format.parse(str);} catch (ParseException e) {e.printStackTrace();}return date;}public static void main(String[] args) {Date date = new Date(); "日期转字符串:" + ConvertDemo.DateToStr(date));"字符串转日期:" +ConvertDemo.StrToDate(ConvertDemo.DateToStr(date)));}}*************************************** 下面的都是例子 ******************************************************* Java中日期格式转换/*** 字符串转换为* 支持格式为 G 'at' hh:mm:ss z 如 '2002-1-1 AD at 22:10:59 PSD'<br>* yy/MM/dd HH:mm:ss 如 '2002/1/1 17:55:00'<br>* yy/MM/dd HH:mm:ss pm 如 '2002/1/1 17:55:00 pm'<br>* yy-MM-dd HH:mm:ss 如 '2002-1-1 17:55:00' <br>* yy-MM-dd HH:mm:ss am 如 '2002-1-1 17:55:00 am' <br>* @param time String 字符串<br>* @return Date 日期<br>*/public static Date stringToDate(String time){SimpleDateFormat formatter;int tempPos=time.indexOf("AD") ;time=time.trim() ;formatter = new SimpleDateFormat (" G 'at' hh:mm:ss z");if(tempPos>-1){time=time.substring(0,tempPos)+"公元"+time.substring(tempPos+"AD".length());//chinaformatter = new SimpleDateFormat (" G 'at' hh:mm:ss z");}tempPos=time.indexOf("-");if(tempPos>-1&&(time.indexOf(" ")<0)){formatter = new SimpleDateFormat ("yyyyMMddHHmmssZ");}else if((time.indexOf("/")>-1) &&(time.indexOf(" ")>-1)){ formatter = new SimpleDateFormat ("yyyy/MM/dd HH:mm:ss");}else if((time.indexOf("-")>-1) &&(time.indexOf("")>-1)){ formatter = new SimpleDateFormat ("yyyy-MM-dd HH:mm:ss");}else if((time.indexOf("/")>-1) &&(time.indexOf("am")>-1)||(time.indexOf("pm")>-1)){formatter = new SimpleDateFormat ("yyyy-MM-dd KK:mm:ss a");}else if((time.indexOf("-")>-1) &&(time.indexOf("am")>-1)||(time.indexOf("pm")>-1)){formatter = new SimpleDateFormat ("yyyy-MM-dd KK:mm:ss a");}ParsePosition pos = new ParsePosition(0);ctime = formatter.parse(time, pos);return ctime;}/*** 将格式转换为字符串格式'yyyy-MM-dd HH:mm:ss'(24小时制)<br>* 如Sat May 11 17:24:21 CST 2002 to '2002-05-11 17:24:21'<br> * @param time Date 日期<br>* @return String 字符串<br>*/public static String dateToString(Date time){SimpleDateFormat formatter;formatter = new SimpleDateFormat ("yyyy-MM-dd HH:mm:ss");String ctime = formatter.format(time);return ctime;}/*** 将格式转换为字符串格式'yyyy-MM-dd HH:mm:ss a'(12小时制)<br> * 如Sat May 11 17:23:22 CST 2002 to '2002-05-11 05:23:22 下午'<br> * @param time Date 日期<br>* @param x int 任意整数如:1<br>* @return String 字符串<br>*/public static String dateToString(Date time,intx){ SimpleDateFormat formatter;formatter = new SimpleDateFormat ("yyyy-MM-dd KK:mm:ss a");String ctime = formatter.format(time);return ctime;}/***取系统当前时间:返回只值为如下形式*2002-10-30 20:24:39* @return String*/public static String Now(){return dateToString(new Date());}/***取系统当前时间:返回只值为如下形式*2002-10-30 08:28:56 下午*@param hour 为任意整数*@return String*/public static String Now(int hour){return dateToString(new Date(),hour);}/***取系统当前时间:返回值为如下形式*2002-10-30*@return String*/public static String getYYYY_MM_DD(){return dateToString(new Date()).substring(0,10);}/***取系统给定时间:返回值为如下形式*2002-10-30*@return String*/public static String getYYYY_MM_DD(String date){ return date.substring(0,10);}public static String getHour(){SimpleDateFormat formatter;formatter = new SimpleDateFormat ("H");String ctime = formatter.format(new Date());return ctime;}public static String getDay(){SimpleDateFormat formatter;formatter = new SimpleDateFormat ("d");String ctime = formatter.format(new Date());return ctime;}public static String getMonth(){SimpleDateFormat formatter;formatter = new SimpleDateFormat ("M");String ctime = formatter.format(new Date());return ctime;}public static String getYear(){SimpleDateFormat formatter;formatter = new SimpleDateFormat ("yyyy");String ctime = formatter.format(new Date());return ctime;}public static String getWeek(){SimpleDateFormat formatter;formatter = new SimpleDateFormat ("E");String ctime = formatter.format(new Date());return ctime;}在jsp页面中的日期格式和sqlserver中的日期格式不一样,怎样统一?在页面上显示输出时,用下面的函数处理一下public class DateUtil(){public static String fmtShortEnu(Date myDate){ SimpleDateFormat formatter = newSimpleDateFormat("yyyy/MM/dd");String strDate = formatter.format(myDate);return strDate;}}new "yyyy-MM-dd HH:mm:ss");new "yyyy-MM-dd")建议还是把sqlserver的字段类型改成varchar的吧,用字符串处理可以完全按照自己的意愿处理,没有特殊的需求,不要使用date型字串日期格式转换用的API是SimpleDateFormat,它是属於,所以请记得import进来!用法:SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 这一行最重要,它确立了转换的格式,yyyy是完整的西元年,MM是月份,dd是日期,至於HH:mm:ss就不需要我再解释了吧!ps:为什麽有的格式大写,有的格式小写,那是怕避免混淆,例如MM是月份,mm是分;HH是24小时制,而hh是12小时制1.字串转日期:2002-10-8 15:30:22要把它转成日期,可以用Date date=sdf.parse("2002-10-8 15:30:22");2.日期转字串假如把今天的日期转成字串可用String datestr=sdf.format(new Date());这个字串的内容便类似2002-10-08 14:55:38透过这个API我们便可以随心所欲的将日期转成我们想要的字串格式,例如希望将日期输出成2002年10月08日,我们可以这麽写:SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日"); String datestr=sdf.format(new Date());datestr便会依照我们设定的格式输出//对日期格式的转换成("yyyy-MM-dd")格式的方法public Convert(String str){sdf = new "yyyy-MM-dd");try {d = sdf.parse(str);d1 = new ;return d1;}catch(Exception ex){ex.printStackTrace();return null;}}应用如下:ctmt.setDate(7,this.Convert(info.getManBirth())); // @DATETIME常用日期问题集锦1、获取服务器端当前日期:<%@ page import=""%><%Date myDate = new Date();%>2、获取当前年、月、日:<%@ page import=""%><%Date myDate = new Date();int thisYear = myDate.getYear() + 1900;//thisYear = 2003int thisMonth = myDate.getMonth() + 1;//thisMonth = 5int thisDate = myDate.getDate();//thisDate = 30%>3、按本地时区输出当前日期<%@ page import=""%><%Date myDate = new Date();out.println(myDate.toLocaleString());%>输出结果为:2003-5-304、获取数据库中字段名为”publish_time“、类型为Datetime的值<%@ page import=""%><%...连接数据库...ResultSet rs = ...Date sDate = rs.getDate("publish_time");%>[code]5、按照指定格式打印日期[code]<%@ page import=""%><%@ page import=""%><%Date dNow = new Date();SimpleDateFormat formatter = new SimpleDateFormat("E 'at' hh:mm:ss a zzz");out.println("It is " + formatter.format(dNow));%>输出的结果为:It is 星期五 at 11:30:46 上午 CST(更为详尽的格式符号请参看SimpleDateFormat类)6、将字符串转换为日期<%@ page import=""%><%@ page import=""%><%String input = "1222-11-11";SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd"); Date t = null;try{t = formatter.parse(input);out.println(t);}catch(ParseException e){out.println("unparseable using " + formatter);}%>输出结果为:Fri Nov 11 00:00:00 CST 12227、计算日期之间的间隔<%@ page import=""%><%@ page import=""%><%String input = "2003-05-01";SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd"); Date d1 = null;try{d1 = formatter.parse(input);}catch(ParseException e){out.println("unparseable using " + formatter);}Date d2 = new Date();long diff = d2.getTime() - d1.getTime();out.println("Difference is " + (diff/(1000*60*60*24)) + " days."); %>输出结果为:Difference is 29 days.8、日期的加减运算方法:用Calendar类的add()方法<%@ page import="java.util.*"%><%@ page import="java.text.*"%><%Calendar now = Calendar.getInstance();SimpleDateFormat formatter = new SimpleDateFormat("E 'at' hh:mm:ss a zzz");out.println("It is now " + formatter.format(now.getTime()));now.add(Calendar.DAY_OF_YEAR,-(365*2));out.println("<br>");out.println("Two years ago was " + formatter.format(now.getTime())); %>输出结果为:It is now 星期五 at 01:45:32 下午 CSTTwo years ago was 星期三 at 01:45:32 下午 CST9、比较日期方法:用equals()、before()、after()方法<%@ page import="java.util.*"%><%@ page import="java.text.*"%><%DateFormat df = new SimpleDateFormat("yyy-MM-dd");Date d1 = df.parse("2000-01-01");Date d2 = df.parse("1999-12-31");String relation = null;if(d1.equals(d2))relation = "the same date as";else if(d1.before(d2))relation = "before";elserelation = "after";out.println(d1 +" is " + relation + ' ' + d2);%>输出结果为:Sat Jan 01 00:00:00 CST 2000 is after Fri Dec 31 00:00:00 CST 199910、记录一件事所花费的时间方法:调用两次System.getTimeMillis()方法,求差值<%@ page import="java.text.*"%><%long t0,t1;t0 = System.currentTimeMillis();out.println("Cyc starts at " + t0);int k = 0;for(int i =0;i<100000;i++){k += i;}t1 = System.currentTimeMillis();out.println("<br>");out.println("Cyc ends at " + t1);out.println("<br>");out.println("This run took " + (t1-t0) + "ms.");%>输出结果为:Cyc starts at 12432Cyc ends at 12442This run took 10ms.其它:如何格式化小数<%@ page import="java.text.*"%><%DecimalFormat df = new DecimalFormat(",###.00");double aNumber = 856.6568975;String result = df.format(aNumber);out.println(result);%>输出结果为:33,665,448,856.66======================日期比较:在JAVA中日期的计算与比较可以使用Date和DateFormat来解决,下面是一段示例代码:import java.text.*;import java.util.*;public class Test{public static void main(String[] args){try{Date date=new Date();DateFormat df=DateFormat.getDateTimeInstance();String now=df.format(date);"现在时间:"+now);"现在时间是否在16:00之前:"+date.before(df.parse("2004-12-24 16:00:00")));}catch(ParseException e){;}}}***************************************************** 有是一段例子 *****************************************************小例1:import ;import ;import ;public class Text { public static void main(String[] args){SimpleDateFormat dd=newSimpleDateFormat("yyyy-MM-dd");String d=dd.format(new Date());;try {Date date=dd.parse("2007-12-12");;} catch (ParseException e) {e.printStackTrace();}}}下面是把Int整数转换成Dateimport ;import ;import ;public class Text {public static void main(String[] args){SimpleDateFormat dd=new SimpleDateFormat("yyyyMMdd");String d=dd.format(new Date());;int ddd=;try {Date date=dd.parse(ddd);;} catch (ParseException e) {e.printStackTrace();}}}---------------------------------------------------------------- 小例2:如何获取当前时间?String now=new SimpleDateFormat("yyyy-MM-ddHH:mm:ss").format(Calendar.getInstance().getTime());Date createDate=convertDate(now); //转换成Date型//将字符串转换成日期型的方法;public Date convertDate(String planedDate){Date date=new Date();SimpleDateFormat dd=new SimpleDateFormat("yyyy-MM-dd");String d=dd.format(new Date());;try {date=dd.parse(planedDate); ;} catch (ParseException e) {e.printStackTrace();return null;}return date;}---------------------------------------------------------------- 小例3:如何获得系统的year,month,day?Calendar c = Calendar.getInstance();c.setTime(new ;int year = c.get(Calendar.YEAR);int month = c.get(Calendar.MONTH)+1;int day = c.get(Calendar.DAY_OF_MONTH);int hour = c.get(Calendar.HOUR_OF_DAY);int minute = c.get(Calendar.MINUTE);int second = c.get(Calendar.SECOND);---------------------------------------------------------------- 小例4:JAVA中获得本地系统时间的方法import java.util.*;public class D{public static void main(String []abc){int y,m,d,h,mi,s;Calendar cal=Calendar.getInstance();y=cal.get(Calendar.YEAR);m=cal.get(Calendar.MONTH);d=cal.get(Calendar.DATE);h=cal.get(Calendar.HOUR_OF_DAY);mi=cal.get(Calendar.MINUTE);s=cal.get(Calendar.SECOND);"现在时刻是"+y+"年"+m+"月"+d+"日"+h+"时"+mi+"分"+s+"秒");}}###########################################################public class Main{public static void main(String[] args){c=; f=new "yyyy年MM月dd日hh时mm分ss秒");;}}----------------------------------------------------------------小例5:1>先导入两个类java.util.*; java.text.*;2>加简单的一句话:String date=new SimpleDateFormat("yyyy-MM-ddHH:mm:ss").format(Calendar.getInstance).getTime());date就是你得到的时间,显示格式可以根据("yyyy-MM-dd HH:mm:ss")的格式随意调整----------------------------------------------------------------小例6:在JSP页面上可以通过一下方法获取:function printDate(){var today=new Date();var day=today.getDate();var month=today.getMonth()+1;var year=today.getFullYear().toString();var box1=;if((month/10)<1){month=("0"+month).toString();}if((day/10)<1){day=("0"+today.getDate()).toString();}box1.value=year+"-"+month+"-"+day;}。

JavaDate时间转换String类型或String时间格式字符串转Date类型

JavaDate时间转换String类型或String时间格式字符串转Date类型

JavaDate时间转换String类型或String时间格式字符串转Date类型Java时间格式转换⼤全import java.text.*;import java.util.Calendar;public class VeDate {/*** 获取现在时间** @return返回时间类型 yyyy-MM-dd HH:mm:ss*/public static Date getNowDate() {Date currentTime = new Date();SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateString = formatter.format(currentTime);ParsePosition pos = new ParsePosition(8);Date currentTime_2 = formatter.parse(dateString, pos);return currentTime_2;}/*** 获取现在时间** @return返回短时间格式 yyyy-MM-dd*/DateFormat format1 = new SimpleDateFormat("yyyy-MM-dd");DateFormat format 2= new SimpleDateFormat("yyyy年MM⽉dd⽇ HH时mm分ss秒");Date date = null;String str = null;// String转Datestr = "2007-1-18";try {date = format1.parse(str);data = format2.parse(str);} catch (ParseException e) {e.printStackTrace();}/*** 获取现在时间** @return返回字符串格式 yyyy-MM-dd HH:mm:ss*/public static String getStringDate() {Date currentTime = new Date();SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateString = formatter.format(currentTime);return dateString;}/*** 获取现在时间** @return返回短时间字符串格式yyyy-MM-dd*/public static String getStringDateShort() {Date currentTime = new Date();SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");String dateString = formatter.format(currentTime);return dateString;}/*** 获取时间⼩时:分;秒 HH:mm:ss** @return*/public static String getTimeShort() {SimpleDateFormat formatter = new SimpleDateFormat("HH:mm:ss");Date currentTime = new Date();String dateString = formatter.format(currentTime);return dateString;}/*** 将长时间格式字符串转换为时间 yyyy-MM-dd HH:mm:ss** @param strDate* @return*/public static Date strToDateLong(String strDate) {SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");ParsePosition pos = new ParsePosition(0);Date strtodate = formatter.parse(strDate, pos);return strtodate;}/*** 将长时间格式时间转换为字符串 yyyy-MM-dd HH:mm:ss** @param dateDate* @return*/public static String dateToStrLong(java.util.Date dateDate) {SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateString = formatter.format(dateDate);return dateString;}/*** 将短时间格式时间转换为字符串 yyyy-MM-dd** @param dateDate* @param k* @return*/public static String dateToStr(java.util.Date dateDate) {SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");String dateString = formatter.format(dateDate);return dateString;}/*** 将短时间格式字符串转换为时间 yyyy-MM-dd** @param strDate* @return*/public static Date strToDate(String strDate) {SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");ParsePosition pos = new ParsePosition(0);Date strtodate = formatter.parse(strDate, pos);return strtodate;}/*** 得到现在时间** @return*/public static Date getNow() {Date currentTime = new Date();return currentTime;}/*** 提取⼀个⽉中的最后⼀天** @param day* @return*/public static Date getLastDate(long day) {Date date = new Date();long date_3_hm = date.getTime() - 3600000 * 34 * day;Date date_3_hm_date = new Date(date_3_hm);return date_3_hm_date;}/*** 得到现在时间** @return字符串 yyyyMMdd HHmmss*/public static String getStringToday() {Date currentTime = new Date();SimpleDateFormat formatter = new SimpleDateFormat("yyyyMMdd HHmmss");String dateString = formatter.format(currentTime);return dateString;}/*** 得到现在⼩时*/public static String getHour() {Date currentTime = new Date();SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateString = formatter.format(currentTime);String hour;hour = dateString.substring(11, 13);return hour;}/*** 得到现在分钟** @return*/public static String getTime() {Date currentTime = new Date();SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateString = formatter.format(currentTime);String min;min = dateString.substring(14, 16);return min;}/*** 根据⽤户传⼊的时间表⽰格式,返回当前时间的格式如果是yyyyMMdd,注意字母y不能⼤写。

java datetime转date的方法

java datetime转date的方法

java datetime转date的方法Java中可以使用`java.util.Date`和`java.sql.Date`来实现`datetime`转换为`date`的方法。

1. 使用`java.util.Date`:```javaimport java.text.DateFormat;import java.text.ParseException;import java.text.SimpleDateFormat;import java.util.Date;public class DateTimeConverter {public static void main(String[] args) {String dateTimeString = "2021-12-31 23:59:59";DateFormat inputFormat = new SimpleDateFormat("yyyy-MM-ddHH:mm:ss");Date dateTime;try {dateTime = inputFormat.parse(dateTimeString);DateFormat outputFormat = new SimpleDateFormat("yyyy-MM-dd");String date = outputFormat.format(dateTime);System.out.println(date);} catch (ParseException e) {e.printStackTrace();}}}```以上代码将字符串类型的日期时间转换为`Date`对象,然后再使用`SimpleDateFormat`将`Date`对象转换为指定格式的字符串日期。

2. 使用`java.sql.Date`:```javaimport java.sql.Timestamp;public class DateTimeConverter {public static void main(String[] args) {String dateTimeString = "2021-12-31 23:59:59";Timestamp timestamp = Timestamp.valueOf(dateTimeString);java.sql.Date date = new java.sql.Date(timestamp.getTime());System.out.println(date);}}```以上代码使用`Timestamp`类先将字符串类型的日期时间转换为`Timestamp`对象,然后再使用`getTime()`方法获取毫秒数,最后使用`java.sql.Date`类将毫秒数转换为`date`对象。

JDBC操作数据库Date类型数据

JDBC操作数据库Date类型数据

JDBC操作数据库Date类型数据JDBC操作数据库Date类型数据由于java原⽣的⼯具类java.util提供的Date对象与JDBC提供的Date对象并不相同分别是java.util.Date和java.sql.Datejava.sql.Date是java.util.Date的⼦类所以在进⾏增删改查部分操作中,不能直接将原⽣⼯具类的Date对象直接运⽤到JDBC中可以将java.sql.Date直接转换成java.util.Date使⽤SimpleDateFormat转换SimpleDateFormat可以将字符串转换成Util.Date//字符串:⾃定义⽇期String str = "1999-09-09";//将字符串转换为Util.DateSimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");//parse⽅法转换java.util.Date date = simpleDateFormat.parse(str);System.out.println(date);也可以将Util.Date转换成字符串//将Date对象转换成字符串String dates = simpleDateFormat.format(new java.util.Date());System.out.println(dates); //2020-09-14将字符串类型的固定⽇期转换成sql.Datesql.Date不⽀持字符串转换,只⽀持毫秒值创建通过util.Date拿到固定⽇期的毫秒值,再转换成sql.date//字符串:固定⽇期String str = "1999-09-09";//将字符串转换为Util.DateSimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");//parse⽅法转换java.util.Date date = simpleDateFormat.parse(str);System.out.println(date);//通过util.Date拿到指定⽇期的毫秒值,再转换成sql.Datejava.sql.Date sqlDate = new java.sql.Date(date.getTime());System.out.println(sqlDate);将⽇期转换封装成⼯具类package com.qf.Person;import java.text.ParseException;import java.text.SimpleDateFormat;public class DateUtils {//1. 字符串转换成util.Datepublic static java.util.Date strToUtil(String str) {SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");try {java.util.Date date = simpleDateFormat.parse(str);return date;} catch (ParseException e) {e.printStackTrace();}return null;}//2. util.Date 转换成sql.Datepublic static java.sql.Date utilToSql(java.util.Date date) {return new java.sql.Date(date.getTime());}//3. util.Date转换成字符串形式public static String utilToStr(java.util.Date date) {SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");return simpleDateFormat.format(date); }}。

Java时间格式Date和String互相转换

Java时间格式Date和String互相转换

Java时间格式Date和String互相转换⼀常⽤⽅案:SimpleDateFormatpublic class TimeUtils {public static String formatDate(Date date) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");return sdf.format(date);}public static Date parse(String strDate) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {return sdf.parse(strDate);} catch (ParseException e) {e.printStackTrace();}return null;}⼆出现的问题每次调⽤⽅都要new SimpleDateFormat(),每次处理⼀个时间信息的时候,就需要创建⼀个SimpleDateFormat实例对象,然后再丢弃这个对象。

⼤量的对象就这样被创建出来,占⽤⼤量的内存和 jvm空间于是那我就创建⼀个静态的simpleDateFormat实例public class TimeUtils {private static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");public static String formatDate(Date date) {return sdf.format(date);}public static Date parse(String strDate) {try {return sdf.parse(strDate);} catch (ParseException e) {e.printStackTrace();}return null;}但是问题是:线程不安全,在format⽅法⾥,有这样⼀段代码:private StringBuffer format(Date date, StringBuffer toAppendTo,FieldDelegate delegate) {calendar.setTime(date);boolean useDateFormatSymbols = useDateFormatSymbols();for (int i = 0; i < compiledPattern.length; ) {int tag = compiledPattern[i] >>> 8;int count = compiledPattern[i++] & 0xff;if (count == 255) {count = compiledPattern[i++] << 16;count |= compiledPattern[i++];}switch (tag) {case TAG_QUOTE_ASCII_CHAR:toAppendTo.append((char)count);break;case TAG_QUOTE_CHARS:toAppendTo.append(compiledPattern, i, count);i += count;break;default:subFormat(tag, count, delegate, toAppendTo, useDateFormatSymbols);break;}}return toAppendTo;}calendar不是⽅法局部变量⽽是SimpleDateFormat类的全局变量,⽽这就是引发问题的根源。

java处理timestamp以及和date转换关系的总结

java处理timestamp以及和date转换关系的总结

Java中Date及Timestamp时间相关内容(基本上看这一份就可以了)java.util.date java.sql.date java.sql.timestamp整理一:这里的一片文章,我个人认为讲解的很详细,有对 java.sql.Date的使用还有困惑的请看。

java.sql.Date 只存储日期数据不存储时间数据// 会丢失时间数据preparedStatement.setDate(1, new java.sql.Date(date.getTime()));//可以这样来处理preparedStatement.setTimestamp(1, new java.sql.Timestamp(newjava.util.Date().getTime()));//想要得到完整的数据,包括日期和时间,可以这样java.util.Date d = resultSet.getTimestamp(1);//这样处理更合适一些,可以避免一些潜在Timestamp 问题java.util.Date d = newjava.util.Date(resultSet.getTimestamp(1).getTime());自己补的话这样的话:往数据库存储的时候可以接收 java.util.Date类型再用getTime()方法得到代表那个Date对象的long值,再以这个long值构造一个Timestamp 对象存进数据库中。

从存数据库里取的时候,可以先得到Timestamp用他的getTime()方法得到long值,再以这个long值构造一个 java.util.Date对象,这样就可以对这个Date对象操作了。

不如说 new SimpleTimeFormat("yyyyy-MM-ddHH:mm:ss").format()等等整理二:用Timestamp来记录日期时间还是很方便的,但有时候显示的时候是不需要小数位后面的毫秒的,这样就需要在转换为String时重新定义格式。

Java编程之java日期与字符串转化

Java编程之java日期与字符串转化

Java编程之java⽇期与字符串转化1 SimpleDateFormat担当重任,怎样格式化都⾏import java.util.Date;import java.text.SimpleDateFormat;public class Demo {public static void main(String[] args) { Date now=new Date(); SimpleDateFormat f=newSimpleDateFormat("今天是"+"yyyy年MM⽉dd⽇ E kk点mm分"); System.out.println(f.format(now)); f=new SimpleDateFormat("a hh点mm分ss秒"); System.out.println(f.format(now)); }}2 从字符串到⽇期类型的转换:import java.util.Date;import java.text.SimpleDateFormat;import java.util.GregorianCalendar;import java.text.*;public class Demo {public static void main(String[] args) {String strDate="2005年04⽉22⽇";//注意:SimpleDateFormat构造函数的样式与strDate的样式必须相符SimpleDateFormat simpleDateFormat=new SimpleDateFormat("yyyy年MM⽉dd⽇ ");SimpleDateFormat sDateFormat=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //加上时间//必须捕获异常try {Date date=simpleDateFormat.parse(strDate);System.out.println(date);} catch(ParseException px) {px.printStackTrace();}}}3 将毫秒数换转成⽇期类型import java.util.Date;import java.text.SimpleDateFormat;import java.util.GregorianCalendar;import java.text.*;public class Demo {public static void main(String[] args) {long now=System.currentTimeMillis();System.out.println("毫秒数:"+now);Date dNow=new Date(now);System.out.println("⽇期类型:"+dNow);}}4 获取系统时期和时间,转换成SQL格式后更新到数据库java.util.Date d=new java.util.Date(); //获取当前系统的时间//格式化⽇期new java.text.SimpleDateFormat s= new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateStr = s.format(d); //转为字符串5 ⽐较⽇期⼤⼩import java.text.DateFormat;import java.text.SimpleDateFormat;import java.util.Date;public class test {public static void main(String args[]) {int i= compare_date("1995-11-12 15:21", "1999-12-11 09:59");System.out.println("i=="+i);}public static int compare_date(String DATE1, String DATE2) {DateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:mm");try {Date dt1 = df.parse(DATE1);Date dt2 = df.parse(DATE2);if (dt1.getTime() > dt2.getTime()) {System.out.println("dt1 在dt2前");return 1;} else if (dt1.getTime() < dt2.getTime()) {System.out.println("dt1在dt2后");return -1;} else {return 0;}} catch (Exception exception) {exception.printStackTrace();}return 0;}}java ⽇期和字符串转换⽂章中,⽤的API是SimpleDateFormat,它是属于java.text.SimpleDateFormat,所以请记得import进来!⽤法: SimpleDateFormat sdf = new SimpleDateFormat( " yyyy-MM-dd HH:mm:ss " );这⼀⾏最重要,它确⽴了转换的格式,yyyy是完整的公元年,MM是⽉份,dd是⽇期,⾄于HH:mm:ss,为什么有的格式⼤写,有的格式⼩写,那是怕避免混淆,例如MM是⽉份,mm是分;HH是24⼩时制,⽽hh是12⼩时制。

浅谈:字符串、时间格式的转换

浅谈:字符串、时间格式的转换

浅谈:字符串、时间格式的转换字符串与时间格式的转换-----常⽤的⽅法:1、拼接字符串的格式【String类型的⼀些常⽤的⽅法】; 2、simpledateformat格式 3、Date格式1、SimpleDateFormat的⽤法:【定义输出结果的样式,】 SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd"); 1.1常⽤的⽅法: sf.format(Date);将给定Date格式化为⽇期/时间字符串,并将结果添加到给定的StringBuffer sf.parse(String);解析字符串⽂本,⽣成Date类型2、Date的⽤法:【来⾃util包】 Date now = new Date();输出当前系统的时间; now.getTime();返回⾃1970年1⽉1⽇00:00:00以来此date对象表⽰的毫秒数; now.setTime();设置此Date对象,以表⽰1970年1⽉1⽇00:00:00以后time毫秒数的时间 还有now.after(date);now.before(datee);pareTo(date);now.equals(object);都是没有过时的⼀些⽅法,其他的都是过时的⽅法,过时的⽅法有时候⽤起来没有影响,有时候是有影响的; 【过时的⽅法:获取时间的年⽉⽇,或者设置时间的年⽉⽇等等⼀系列的⽅法】3、String的⽤法:【常⽤的⽅法】 String str = "sdasdhaksjdhaskdhk"; char--charAt(index);返回指定索引的char值。

String--concat(String);将指定字符串连接到此字符串的结尾。

int--indexOf(char);返回指定字符串在此字符中第⼀次出现处的索引。

String--indexOf(String);返回指定⼦字符串在此字符串中第⼀次出现处的索引。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1、将java.util.Date转换为java.sql.Datejava.util.Date utilDate = new
java.util.Date();java.sql.Date sqlDate = new java.sql.Date(utilDate.getTime());2、若要插入到数据库并且相应的字段为Date类型可使用
PreparedStatement.setDate(int ,java.sql.Date)方法其中的java.sql.Date可以用上面的方法得到也可以用数据库提供TO_DATE函数比如现有udTO_DATE(new SimpleDateFormat().format(ud,"yy-MM-dd HH:
mm:
ss"),"YY-MM-DD HH24:
MI:
SS")注意java中表示格式和数据库提供的格式的不同sql="update tablename set timer=to_date('"+x+"','yymmddhh24miss') where ....."这里的x为变量为类似:
、如何将"yy-mm-dd"格式的字符串转换为java.sql.Date方法1SimpleDateFormatbartDateFormat =new SimpleDateFormat("yy-MM-
dd");StringdateStringToParse="2007-7-
12";try{java.util.Datedate=bartDateFormat.parse(dateStringToParse);java.sql.Datesql Date=new java.sql.Date(date.getTime());System.out.println(sqlDate.getTime());}catch (Exception ex) {System.out.println(ex.getMessage());}方法2StringstrDate="2002-08-09";StringTokenizerst=newStringTokenizer(strDate, "-");java.sql.Date
date=newjava.sql.Date(Integer.parseInt(st.nextToken()));java.util.Date和
java.sql.Date的区别java.sql.Date,java.sql.Time和java.sql.Timestamp三个都是java.util.Date的子类(包装类)。

但是为什么java.sql.Date类型的值插入到数据库中Date字段中会发生数据截取呢?java.sql.Date是为了配合SQL DATE而设置的数据类型。

“规范化”的java.sql.Date只包含____年__月__日信息,时分秒毫秒都会清零。

格式类似:
YY-MM-DD。

当我们调用ResultSet的getDate()方法来获得返回值时,java程序会参照"规范"的java.sql.Date来格式化数据库中的数值。

因此,如果数据库中存在的非规范化部分的信息将会被劫取。

在sun提供的ResultSet.java中这样对getDate进行注释的:
Retrieves the of the designated column in the current row of this
<code>ResultSet</code> objectas a “java.sql.Date” object in the Java programming language.同理。

如果我们把一个java.sql.Date值通过PrepareStatement的setDate方法存入数据库时,java程序会对传入的java.sql.Date规范化,非规范化的部分将会被劫取。

然而,我们java.sql.Date一般由java.util.Date转换过来,如:
java.sql.Date sqlDate=new java.sql.Date(newjava.util.Date().getTime()).显然,这样转换过来的java.sql.Date往往不是一个规范的java.sql.Date.要保存
java.util.Date的精确值,我们需要利用java.sql.Timestamp.Calendar:
Calendar calendar=Calendar.getInstance();//获得当前时间,声明时间变量int year=calendar.get(Calendar.YEAR);//得到年int
month=calendar.get(Calendar.MONTH);//得到月,但是,月份要加上
1month=month+1;int date=calendar.get(Calendar.DATE);//获得日期String
today=""+year+"-"+month+"-"+date+"";字符串转换成日期时间格式//日期时间格式:
yy-MM-dd hh:
mm:
ssString time ="1900-02-21 12:
23:
33";//将字符串转换为日期和时间SimpleDateFormat dateformat = new SimpleDateFormat("yy-MM-dd hh:
mm:
ss");//生成的日期和时间Date date = dateformat .parse(time);。

相关文档
最新文档