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;
//发布⼈id
private String releaseId;
//是否发布,1发布,0保存
private Integer released;
//接收⼈id,对应tb_base_information_receiver的主键
private String receiver;
//创建时间就是发布时间
private Date createDate;
/
/更新时间
private Date updateDate;
//开始时间
private Date beginDate;
//结束时间
private Date endDate;
//定时器,规定什么时候发布信息
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 '发布⼈id',
`released` int(11) DEFAULT NULL COMMENT '是否发送,1发送0保存为草稿',
`create_date` datetime DEFAULT NULL COMMENT '创建时间',
`update_date` datetime DEFAULT NULL COMMENT '更新时间',
`begin_date` datetime DEFAULT NULL COMMENT '信息有效期的起始时间',
`end_date` datetime DEFAULT NULL COMMENT '信息有效期的结束时间',
`timer` datetime DEFAULT NULL COMMENT '定时器,指定发送信息的时间',
`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='信息发布表';
页⾯
<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/>
创建时间:<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("Parameter(createDate)" + Parameter("createDate"));
Date createDate = new SimpleDateFormat("yyyy-MM-dd").Parameter("createDate"));
Date updateDate = new SimpleDateFormat("yyyy-MM-dd").Parameter("createDate"));
Date beginDate = new SimpleDateFormat("yyyy-MM-dd").Parameter("beginDate"));
Date endDate = new SimpleDateFormat("yyyy-MM-dd").Parameter("endDate"));
Date timer = new SimpleDateFormat("yyyy-MM-dd").Parameter("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 [ateDate,typeMismatch.java.util.Date,typeMismatch]; arguments [t.support.De    at org.hod.solveArgument(ModelAttributeMethodProcessor.java:117)
at org.hod.solveArgument(HandlerMethodArgumentResolverComposite.java:121)
at org.hod.MethodArgumentValues(InvocableHandlerMethod.java:158)
at org.hod.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:128)
at org.springframework.web.hod.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:97)
at org.springframework.web.hod.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:827)
at org.springframework.web.hod.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:738)
at org.springframework.web.hod.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的类型转换失败,此时在实体中,对需要进⾏转换的类型添加如下注解,实现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.</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.8.8</version>
</dependency>
<dependency>
<groupId>com.</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.8.8</version>
string转date的方法</dependency>
<dependency>
<groupId&dehaus.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>
以上为个⼈经验,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。