数据库日期时间显示在页面上格式错误的解决方案

做项目过程中肯定会碰到这样一个问题:在数据库中存的是date或datetime类型的值,从数据库里取出来遍历到页面上显示的是long类型或是GTM类型的日期时间。
对于这个问题,经过研究之后有以下结论:

1.hibernate不会出现这样的问题,而mabatis则会出现这个问题。

2.数据库使用date类型的在页面上会显示long类型日期时间,使用datetime类型的在页面上会显示GTM类型日期时间。

 

因为我用的是mysql数据库,其他的数据库没测试过,所以也不知道其他数据库是怎样的情况,这里就针对mybatis+mysql数据库的情况来说一下我的解决方案吧。

通用解决方案:将实体类中的参数从Date类型换成String类型,一招治百病,但是如果不想通过这种方式解决的童鞋请往下看~

出现GTM时间(格林时间)的解决方案:

方案一(自定义,从后台着手解决问题):在后台把数据封装到一个Map里,key为格式化之后的时间字符串,然后在前台遍历map时,取值为{map.key}就行了。ps:自定义的解决方式,仅供参考~

方案二(推荐,从前端着手解决问题):之前没想到jstl标签库也可以格式化处理数据这一茬,所以后来还是用的这种方案。本着能在前端解决的事绝不放在后台解决,减轻服务器压力的原则,我果断的选择了这一种方法~(其实是这种方式简单,想偷懒而已...)

普通web项目引入jar包,maven项目添加jstl依赖,添加依赖可参考:http://www.cnblogs.com/ggqzz/p/8421734.html

引入标签:

<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>

在遍历日期的位置添加代码

<fmt:formatDate type="both" value="${order.orderTime}" />

出现Long类型时间的解决方案:

方案一:jstl标签库fmt标签,这个上面讲过,就不多说了。

因为这一个项目是用easyui完成的,并且数据是由datagrid遍历出来的,并没有使用el表达式,所以我用的下面2种方式。

方案二:使用datagrid自带formatter(格式化列)的属性,可以直接定义函数,然后在需要格式化的列上加上formatter="函数名"(注意后面不需要加括号)的属性就OK了。

自定义函数,实际上这也是js格式化时间的一种方式:

function formatDate(val) {var date = new Date(val);var y = date.getFullYear();var m = date.getMonth() + 1;var d = date.getDate();return y + '-' + m + '-' + d; }

方式三(推荐):这种方式是使用jackson提供的注解,个人感觉还是很好用的~

先引入依赖:

<!-- jackson-databind依赖 --><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.9.2</version></dependency>

在实体类Date类型属性上加上注解:

@JsonFormat(pattern="yyyy-MM-dd",timezone="GMT+8")private Date openDate;

注意:timezone="GMT+8"这个属性必须加上,不然时区不对会导致日期的偏差!这种方式也格式化不了GTM时间!

以后如果有更多此问题的解决方案我也会继续更新的,欢迎留言讨论~

转载于:https://www.cnblogs.com/ggqzz/p/8438757.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/414709.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2、jeecg 笔记之 t:dictSelect 或 t:dgCol 自定义字典

1、需求 先说一下需求场景吧&#xff0c;我们知道 jeecg 中提供了下拉&#xff0c;其中包含两种使用场景&#xff1b; 一种是直接通过 t:dictSelect 使用&#xff0c;再就是 t:dgCol 用于表头的列表工具条标签&#xff1b; 总之就是这个样子 需求来了&#xff0c;我们想要下拉…

工作234:按钮禁用

<!--定义一个有按钮的对话框 相当于dialog和按钮组合使用--> <template><!-- 有按钮的对话框 这个位置的代码会被包裹过去--><!--close-on-click-modal 是否可以通过点击 modal 关闭 Dialog append-to-body控制不能出现遮挡层--><el-dialog:title&q…

android动态切换logo和label

注&#xff1a;更新版本时。需换为默认的才可以更新apk android:enabled"true"为默认 1、准备资源 &#xff08;1&#xff09;logo和名称资源 <string name"app_name">httpheader</string> <string name"app_name1">第二名&…

洛谷 P4016 负载平衡问题 【最小费用最大流】

求出平均数sum&#xff0c;对于大于sum的点连接(s,i,a[i]-sum,0)&#xff0c;表示这个点可以流出多余的部分&#xff0c;对于小于sum的点连接(i,t,sum-a[i],0)表示这个点可以接受少的部分&#xff0c;然后每个点向相邻的两个点连(i,j,inf,1)表示可以任意转移&#xff0c;每转移…

3、jeecg 笔记之 模糊查询

1、前言 jeecg 考虑到默认模糊查询的话&#xff0c;会增加系统压力&#xff0c;导致查询慢&#xff0c;本来系统就挺那啥的... 2、方式一之实体赋值 实体重新赋值查询&#xff0c;用 * %% * 实现&#xff0c;我们知道 sql 中通常使用 % 去模糊查询的&#xff0c;jeecg 中 datag…

工作235:splice

const user res.data.user;const dept user.department;console.log(dept.property)const properties dept.property.split(",");console.log(properties) 运行结果

java打印三角形,菱形。任意边长大小

一、等腰三角形 for (int j 0; j < num; j) { if (j > 0) { for (int i 0; i < j; i) { if (i j - 1) { for (int k 0; k < num - j; k) { if (k num - j - 1) { Syst…

django-form and fields validation

参考资料 清除数据与表单验证 清除数据时会进行表单验证。 在表格处理时有三种clean方法可调用&#xff0c;通常是在对表单调用is_valid()时执行。clean响应&#xff1a;一般有两种结果&#xff0c;如果处理的数据有问题&#xff0c;则抛出ValidationError错误信息&#xff1b;…

1、vue 笔记之 组件

1、组件个人理解&#xff1a; <组件>是页面的一部分&#xff0c;将界面切分成部分&#xff0c;每部分称为 <组件>2、组件化思想&#xff1a; //2.1、定义一个全局的组件&#xff0c;组件支持‘驼峰命名’规则Vue.component("TodoItem",{props: [content]…

工作236:点击直接进入

<div class"container"><!-- <el-radio-group v-model"mode">--><div><!-- <el-radio-button class"login-btn" label"0">营销端</el-radio-button>--><el-button class"login-b…

java spring框架使用实例demo

首先导入spring的jar包 1、创建web项目&#xff0c;创建spring.xml文件 注&#xff1a;base-package即是包名 spring.xml详情&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <!-- 查找最新的schemaLocation 访问 http://www.springfram…

语料库

http://blog.sina.com.cn/s/blog_66dfbcca0100r3ex.html转载于:https://www.cnblogs.com/lhuser/p/8445287.html

工作237:vuex取值

1获取vuex的取值 /*通过vuex的状态去判断现在所处的业务端还是营销端*/computed:{/*取出对应的业务端和营销端的内容*/Mode(){return this.$store.state.mode}}, 2直接赋值 task_business_module(){getAction(/task/task_business_module).then(res > {this.menus res.da…

2、Flutter 填坑记录篇

1、前言 之前写了一篇文章关于 flutter 初体验的一篇&#xff0c;https://www.cnblogs.com/niceyoo/p/9240359.html&#xff0c;当时一顿骚操作&#xff0c;然后程序就跑起来了。 隔了好一段时间&#xff0c;换了个电脑&#xff0c;重新装了个AndroidStudio&#xff0c;继续搭建…

为何setRequestMethod(GET)不生效

在上传文件时&#xff0c;想使用setRequestMethod&#xff08;“GET”&#xff09;。结果无效 因为需要使用输出流上传文件&#xff0c;而使用输出流时&#xff0c;HttpURLConnection默认使用post请求。是无法更改的 conn.setDoOutput(true); //允许输出流 与 conn.setR…

工作238:Vue.js中this.$nextTick()的使用

this.$nextTick()将回调延迟到下次 DOM 更新循环之后执行。在修改数据之后立即使用它&#xff0c;然后等待 DOM 更新。它跟全局方法 Vue.nextTick 一样&#xff0c;不同的是回调的 this 自动绑定到调用它的实例上。 假设我们更改了某个dom元素内部的文本&#xff0c;而这时候我…

拉勾网大数据相关岗位数据爬虫分析

拉勾网大数据相关招聘数据分析 观察对象&#xff1a;大数据相关岗位的招聘数据 观察时间&#xff1a;2016.3.28 数据来源&#xff1a;拉勾网 1、分析目的 眼下&#xff0c;大数据是一个非常热门的话题。受到非常多人的关注和追捧。其创造的相关职业也受到大家的青睐。但大数据相…

3、Finished with error: FormatException: Bad UTF-8 encoding 0xc3 (at offset 169)

这是由于 app 的版本为 release 找不到 keystore 文件&#xff0c; 我们只需要在 app 下的 build.gradle 文件中修改为 signingConfigs.debug 即可&#xff1a; buildTypes {release {signingConfig signingConfigs.debugproguardFiles getDefaultProguardFile(proguard-androi…

plsql 弹出 register,plsql注册码

注册码&#xff1a; Product Code&#xff1a;4t46t6vydkvsxekkvf3fjnpzy5wbuhphqz serial Number&#xff1a;601769 password&#xff1a;xs374ca https://blog.csdn.net/ma141982/article/details/76154919/

2018--20179215--《文献管理与信息分析》第三讲 英文数据库资源的发展趋势和利用...

《文献管理与信息分析》第三讲 英文数据库资源的发展趋势和利用 一、科研相关的文献资源有以下十大来源&#xff1a; 专利、会议论文、期刊、学位论文、科技报告、科技档案、产品资料、政府出版物、标准文献、图书。 二、数据库的使用 1.不同搜索引擎的差异&#xff1a; 覆盖的…