`

Java.sql.date 与 java.util.date的转化(一)

    博客分类:
  • jdk
阅读更多
Java.sql.date 与 java.util.date
java.util.Date 就是在除了SQL语句的情况下面使用
java.sql.Date 是针对SQL语句使用的,它只包含日期而没有时间部分

它都有getTime方法返回毫秒数,自然就可以直接构建
java.util.Date d = new java.util.Date(sqlDate.getTime());

java.util.Date 是 java.sql.Date 的父类(注意拼写)


前者是常用的表示时间的类,我们通常格式化或者得到当前时间都是用他

后者之后在读写数据库的时候用他,因为PreparedStament的setDate()的第2参数和ResultSet的getDate()方法的第
2个参数都是java.sql.Date

转换是
java.sql.Date date=new java.sql.Date();
java.util.Date d=new java.util.Date (date.getTime());

反过来是一样的

继承关系:java.lang.Object -> java.util.Date -> java.sql.Date

具体的转换关系就是java.util.Date d=new java.util.Date (new Java.sql.Date());



SimpleDateFormat f=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");

java.util.Date utilDate=new Date();      

java.sql.Date sqlDate=new java.sql.Date(utilDate.getTime());  

     

java.sql.Time sTime=new java.sql.Time(utilDate.getTime());

      

java.sql.Timestamp stp=new java.sql.Timestamp(utilDate.getTime());

            

System.out.println(utilDate.getYear());



这里所有时间日期都可以被SimpleDateFormat格式化format()

f.format(stp);f.format(sTime);f.format(sqlDate);f.format(utilDate)

java.sql.Date sqlDate=java.sql.Date.valueOf("2005-12-12");

utilDate=new java.util.Date(sqlDate.getTime());





另类取得年月日的方法:

import java.text.SimpleDateFormat;

import java.util.*;

java.util.Date date = new java.util.Date();

//如果希望得到YYYYMMDD的格式SimpleDateFormat 

sy1=new SimpleDateFormat("yyyyMMDD");

String dateFormat=sy1.format(date);

//如果希望分开得到年,月,日SimpleDateFormat 

sy=new SimpleDateFormat("yyyy");

SimpleDateFormat sm=new SimpleDateFormat("MM");

SimpleDateFormat sd=new SimpleDateFormat("dd");

String syear=sy.format(date);

String smon=sm.format(date);

String sday=sd.format(date);



//End
 
 

Java日期操作常用方法

先来一个:  

取得指定月份的第一天与取得指定月份的最后一天  



              /**  

                *         取得指定月份的第一天  

                *  

                *         @param         strdate         String  

                *         @return         String  

                */  

              public         String         getMonthBegin(String        
 strdate)  

              {  

                      java.util.Date         date         =         
parseFormatDate(strdate);  

                      return         
formatDateByFormat(date,"yyyy-MM")         +         "-01";  

              }  



              /**  

                *         取得指定月份的最后一天  

                *  

                *         @param         strdate         String  

                *         @return         String  

                */  

              public         String         getMonthEnd(String         
strdate)  

              {  

                      java.util.Date         date         =         
parseFormatDate(getMonthBegin(strdate));  

                      Calendar         calendar         =         
Calendar.getInstance();  

                      calendar.setTime(date);  

                      calendar.add(Calendar.MONTH,1);  

                      calendar.add(Calendar.DAY_OF_YEAR,         -1);  

                      return         formatDate(calendar.getTime());  

              }  



              /**  

                *         常用的格式化日期  

                *  

                *         @param         date         Date  

                *         @return         String  

                */  

              public         String         
formatDate(java.util.Date         date)  

              {  

                      return         
formatDateByFormat(date,"yyyy-MM-dd");  

              }  



              /**  

                *         以指定的格式来格式化日期  

                *  

                *         @param         date         Date  

                *         @param         format         String  

                *         @return         String  

                */  

              public         String         
formatDateByFormat(java.util.Date         date,String         format)  

              {  

                      String         result         =         "";  

                      if(date         !=         null)  

                      {  

                              try  

                              {  

                                      SimpleDateFormat         
sdf         =         new         SimpleDateFormat(format);  

                                      result         =         
sdf.format(date);  

                              }  

                              catch(Exception         ex)  

                              {  

                                      LOGGER.info("date:"         
+         date);  

                                      ex.printStackTrace();  

                              }  

                      }  

                      return         result;  

              }  






分享到:
评论

相关推荐

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

    java.util.Date utilDate = new java.util.Date(sqlDate.getTime()); ``` #### 三、字符串转换为日期时间格式 将字符串转换为日期时间格式通常需要用到`SimpleDateFormat`类。下面分别介绍两种常见的字符串到日期...

    java.util.Date与java.sql.Date相互转换

    java.util.Date utilDate = new java.util.Date(sqlDate.getTime()); // java.util.Date 转换为 java.sql.Date java.util.Date utilDate = new java.util.Date(); java.sql.Date sqlDate = new java.sql.Date...

    java.sql.date与java.util.date.pdf

    Java.sql.Date sqlDate = new Java.sql.Date(date.getTime()); System.out.println(sqlDate.getTime()); } catch (Exception ex) { System.out.println(ex.getMessage()); } 方法2: String strDate = "2002-08-...

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

    java.util.Date utilDate = new java.util.Date(sqlDate.getTime()); 二、字符串转换为日期时间格式 可以使用SimpleDateFormat将字符串转换为日期时间格式: String dateStringToParse = "2007-7-12"; ...

    java.sql.与java.util

    Java编程语言提供了两个重要的日期处理类,分别是`java.util.Date`和`java.sql.Date`,它们在处理日期和时间上有着不同的特性和用途。 `java.util.Date`是更通用的日期时间类,它包含了日期和时间的信息,可以精确...

    java_sql_Date与java_util_Date转换

    java_sql_Date与java_util_Date转换

    java.util.Date与java.sql.Date的区别

    在Java编程中,日期处理是常见的任务之一,`java.util.Date` 和 `java.sql.Date` 都是用来表示日期的类,但它们之间存在显著的区别和用法差异。 首先,`java.util.Date` 是 Java 核心库 `java.util` 包中的类,它...

    JAVA String转化成java.sql.date和java.sql.time方法示例

    与String转化成java.sql.Date类似,String转化成java.sql.Time也需要先将String转化成java.util.Date,然后再将java.util.Date转化成java.sql.Time。下面是一个示例代码: ```java public java.sql.Time strToTime...

    Java.util.date与java.sql.date区别和转换

    类型转换 ( Java.util.date与java.sql.date区别和转换

    java.util.Date、java.sql.Date与String三者之间的转换

    此java文件包括常用的日期类型之间的转换,包括java.util.Date、java.sql.Date、String之间的任意类型、格式转换......

    util包里的Date类转换为sql包里的Date

    在Java编程语言中,日期与时间的处理是一个常见的需求,特别是在与数据库交互时。本文将详细介绍如何将`java.util.Date`对象转换为`java.sql.Date`对象,这对于那些需要将日期值存储到数据库中的应用程序来说至关...

    util.date 和 sql.date 相关问题汇总

    java中util.date和sql.date的类型转换问题.帮助大家很完善的了解关于java日期类型和数据库日期类型转换的问题,很值得拥有.

    java完美按格式化字符串String转sql.date

    java.sql.Date sqlDate = stringToSqlDate(dateString, formatStr); System.out.println("Converted SQL Date: " + sqlDate); } catch (Exception e) { e.printStackTrace(); } } } ``` #### 四、代码解释 1...

    Android的SQLite中DateTime类型数据的存取问题

    在 Android 中,使用 java.util.Date 类来表示日期类型数据,而 java.sql.Date 类则是为了配合 SQL DATE 而设置的数据类型。java.sql.Date 类只包含年月日信息,因为数据库中存在的非规范化部分的信息,如时分秒毫秒...

    Javautildate与javasqldate区别和转换[文].pdf

    java.util.Date utilDate = new java.util.Date(sqlDate.getTime()); ``` 在处理日期格式化时,`SimpleDateFormat` 类用于将日期对象转换为字符串或将字符串解析为日期对象。例如: ```java SimpleDateFormat f ...

    java四种时间的区别和联系

    1. **`java.util.Date`与`java.sql.Date`**:`java.sql.Date`继承自`java.util.Date`,但只保留了日期部分,没有时间部分。 2. **`java.util.Date`与`java.sql.Time`**:同理,`java.sql.Time`也继承自`java.util....

Global site tag (gtag.js) - Google Analytics