亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mybatis中string和date的轉換方式

 更新時間:2021年08月06日 11:05:38   作者:beidaol  
這篇文章主要介紹了mybatis中string和date的轉換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

實體里用的java.util.date,數據庫用的是datetime,頁面是字符串<input type="date">。將頁面標簽<input type="date">的內容添加到數據庫

實體

public class BaseInformation {
 
    //信息主鍵
    private String id;
    //信息標題
    private String title;
    //信息類型id(需要在數據字典定義)
    private String typeCode;
    //屬性id(需要在數據字典定義)
    private String propertityId;
    //信息可視范圍,部門可見或者整個單位可見,值是組織結構的id
    private String scope;
    //內容
    private String content;
    //發(fā)布人id
    private String releaseId;
    //是否發(fā)布,1發(fā)布,0保存
    private Integer released;
    //接收人id,對應tb_base_information_receiver的主鍵
    private String receiver;
    //創(chuàng)建時間就是發(fā)布時間
    
    private Date createDate;
    //更新時間
    
    private Date updateDate;
    //開始時間
    
    private Date beginDate;
    //結束時間
    
    private Date endDate;
    //定時器,規(guī)定什么時候發(fā)布信息
   
    private Date timer;

。。。。。省略getter和setter

CREATE TABLE `tb_base_information` (
  `id` varchar(48) NOT NULL,
  `title` varchar(128) DEFAULT NULL COMMENT '標題',
  `type_code` varchar(48) DEFAULT NULL COMMENT '類型id(需要在數據字典定義),公告、新聞等',
  `propertity_id` varchar(48) DEFAULT NULL COMMENT '屬性id(需要在數據字典定義)',
  `scope` varchar(255) DEFAULT NULL COMMENT '信息可視范圍,部門可見或者整個單位可見,值是組織結構的id',
  `content` text COMMENT '內容',
  `release_id` varchar(48) DEFAULT NULL COMMENT '發(fā)布人id',
  `released` int(11) DEFAULT NULL COMMENT '是否發(fā)送,1發(fā)送0保存為草稿',
  `create_date` datetime DEFAULT NULL COMMENT '創(chuàng)建時間',
  `update_date` datetime DEFAULT NULL COMMENT '更新時間',
  `begin_date` datetime DEFAULT NULL COMMENT '信息有效期的起始時間',
  `end_date` datetime DEFAULT NULL COMMENT '信息有效期的結束時間',
  `timer` datetime DEFAULT NULL COMMENT '定時器,指定發(fā)送信息的時間',
  `expiry_date` datetime DEFAULT NULL COMMENT '是否永久有效,1是0否',
  `to_top` int(1) DEFAULT NULL COMMENT '信息是否置頂,1置頂,0否',
  `mark_star` int(1) DEFAULT NULL COMMENT '做星標標記用,1在星標公告里顯示,0否',
  `receiver` varchar(48) DEFAULT NULL COMMENT '接收人id,對應tb_base_information_receiver的主鍵',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='信息發(fā)布表';

頁面

<form name="form" method="post" action="/information/test" enctype="multipart/form-data">  
    類型:<input type="text" name="typeCode" ><br/>
    標題:<input type="text" name="title" ><br/>
    內容:<textarea name="content"  cols="30" rows="10"></textarea><br/>
    創(chuàng)建時間:<input type="date" name="createDate"/><br/>
    更新時間:<input type="date" name="updateDate"/><br/>
    有效期開始時間:<input type="date" name="beginDate"/><br/>
    有效期結束時間:<input type="date" name="endDate"/><br/>
    定時器:<input type="date" name="timer"/><br/>  
    <input type="submit" value="提交"> 
</form>

controller

@RequestMapping("/test")
public String test(BaseInformation baseInformation, HttpServletRequest request) throws Exception {
 
    String id = UUID.randomUUID().toString();
    baseInformation.setId(id);
    //baseInformation.setId(UUID.randomUUID().toString().replaceAll("-",""));
    System.out.println("request.getParameter(createDate)" + request.getParameter("createDate"));
 
    Date createDate = new SimpleDateFormat("yyyy-MM-dd").parse(request.getParameter("createDate"));
    Date updateDate = new SimpleDateFormat("yyyy-MM-dd").parse(request.getParameter("createDate"));
    Date beginDate = new SimpleDateFormat("yyyy-MM-dd").parse(request.getParameter("beginDate"));
    Date endDate = new SimpleDateFormat("yyyy-MM-dd").parse(request.getParameter("endDate"));
    Date timer = new SimpleDateFormat("yyyy-MM-dd").parse(request.getParameter("timer"));
    baseInformation.setCreateDate(createDate);
    baseInformation.setUpdateDate(updateDate);
    baseInformation.setBeginDate(beginDate);
    baseInformation.setEndDate(endDate);
    baseInformation.setTimer(timer);
 
    service.save(baseInformation);
    return "information/test";
}

運行結果

Field error in object 'baseInformation' on field 'createDate': rejected value [2018-11-08]; codes [typeMismatch.baseInformation.createDate,typeMismatch.createDate,typeMismatch.java.util.Date,typeMismatch]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [baseInformation.createDate,createDate]; arguments []; default message [createDate]]; default message [Failed to convert property value of type 'java.lang.String' to required type 'java.util.Date' for property 'createDate'; nested exception is org.springframework.core.convert.ConversionFailedException: Failed to convert from type [java.lang.String] to type [java.util.Date] for value '2018-11-08'; nested exception is java.lang.IllegalArgumentException]
    at org.springframework.web.method.annotation.ModelAttributeMethodProcessor.resolveArgument(ModelAttributeMethodProcessor.java:117)
    at org.springframework.web.method.support.HandlerMethodArgumentResolverComposite.resolveArgument(HandlerMethodArgumentResolverComposite.java:121)
    at org.springframework.web.method.support.InvocableHandlerMethod.getMethodArgumentValues(InvocableHandlerMethod.java:158)
    at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:128)
    at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:97)
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:827)
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:738)
    at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967)
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901)
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970)
    at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
    at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:731)

修改方法

修改實體

string和date的類型轉換失敗,此時在實體中,對需要進行轉換的類型添加如下注解,實現(xiàn)java.lang.String和java.util.Date之間自動轉換

@DateTimeFormat(pattern="yyyy-MM-dd")//頁面寫入數據庫時格式化   
@JSONField(format="yyyy-MM-dd")//數據庫導出頁面時json格式化

修改contoller

既然java.lang.String和java.util.Date之間可以自動轉換了,后臺就不需要通過request獲取參數來進行轉換,可以將紅方格中的注釋掉

依賴添加

1.注解@JsonFormat

      <!--JsonFormat-->
 
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
            <version>2.8.8</version>
        </dependency>
 
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.8.8</version>
        </dependency>
 
        <dependency>
            <groupId>org.codehaus.jackson</groupId>
            <artifactId>jackson-mapper-asl</artifactId>
            <version>1.9.13</version>
        </dependency>

2.注解@DateTimeFormat

@DateTimeFormat的使用和@jsonFormat差不多,首先需要引入是spring還有jodatime,spring我就不貼了

  <!-- joda-time -->
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>2.3</version>
        </dependency>

關于@DateTimeFormat和@JsonFormat還可以參考http://chabaoo.cn/article/176268.htm

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Java的RTTI和反射機制代碼分析

    Java的RTTI和反射機制代碼分析

    這篇文章主要涉及了Java的RTTI和反射機制代碼分析的相關內容,在介紹運行時類型識別的同時,又向大家展示了其實例以及什么時候會用到反射機制,內容豐富,需要的朋友可以參考下。
    2017-09-09
  • java實現(xiàn)多線程賣票功能

    java實現(xiàn)多線程賣票功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)多線程賣票功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • SpringBoot中的PUT和Delete請求使用

    SpringBoot中的PUT和Delete請求使用

    這篇文章主要介紹了SpringBoot中的PUT和Delete請求使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Java并發(fā)應用之任務執(zhí)行分析

    Java并發(fā)應用之任務執(zhí)行分析

    這篇文章主要為大家詳細介紹了JavaJava并發(fā)應用編程中任務執(zhí)行分析的相關知識,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2023-07-07
  • 微服務搭建集成Spring Cloud Turbine詳解

    微服務搭建集成Spring Cloud Turbine詳解

    Spring Cloud是一系列框架的有序集合。它利用Spring Boot的開發(fā)便利性巧妙地簡化了分布式系統(tǒng)基礎設施的開發(fā),最終給開發(fā)者留出了一套簡單易懂、易部署和易維護的分布式系統(tǒng)開發(fā)工具包。下面我們來詳細了解一下吧
    2019-06-06
  • Android 判斷真機和模擬器的方法

    Android 判斷真機和模擬器的方法

    這篇文章主要介紹了 Android 判斷真機和模擬器的方法的相關資料,需要的朋友可以參考下
    2017-02-02
  • JAVA線程池原理實例詳解

    JAVA線程池原理實例詳解

    這篇文章主要介紹了JAVA線程池原理,結合實例形式詳細分析了java線程池概念、原理、創(chuàng)建、使用方法及相關注意事項,需要的朋友可以參考下
    2019-03-03
  • Java Spring事務的隔離級別詳解

    Java Spring事務的隔離級別詳解

    這篇文章主要介紹了Java Spring事務的隔離級別,分享了相關代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2021-10-10
  • Java--Socket通信(客戶端服務端雙向)

    Java--Socket通信(客戶端服務端雙向)

    這篇文章主要介紹了Java--Socket通信(客戶端服務端雙向),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 詳解Java線程池隊列中的延遲隊列DelayQueue

    詳解Java線程池隊列中的延遲隊列DelayQueue

    這篇文章主要為大家詳細介紹了Java線程池隊列中的延遲隊列DelayQueue的相關資料,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2022-12-12

最新評論