解决jsp页面前台时间列显示多一个.0

本文介绍了一种在前后端开发中解决时间格式不一致的方法,通过使用SimpleDateFormat将数据库中的datetime类型转换为String类型,再由前端展示,确保时间格式正确显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前台时间显示格式不正确

如图:
在这里插入图片描述
这个情况是因为数据库(我当时用的是mysql)存储时间的数据类型是datetime,而后台接收的数据类型是String。
这个涉及到了datetime与String之间的转换
以下为例:

SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
//查看某一个用户的详细信息
	public UserBean getLookOneUser(int id) {
		// 根据参数 id 在数据库中进行查询
		UserBean ub = null; //这个需要创建在try外面,要不然下面返回时候找不到,先给null这样方便以后的返回
		String sql = "select * from usertable where id = "+id;
		
		
		try {
			ResultSet rs = jt.select(sql);			
			while(rs.next()){
				ub = new UserBean();
				ub.setId(rs.getInt(1));
				ub.setName(rs.getString(2));
				ub.setAge(rs.getInt(3));
				ub.setSex(rs.getInt(4));
				ub.setBirthday(formatter.format(rs.getDate(5)));
				ub.setPs(rs.getString(6));
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			jt.guanBi();
		}
		return ub;
	}

这样运行后前台时间格式显示的就正确了

//String转换为java.util.Date  
String str = "2013-01-14 12:15:13";  
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
Date date = null; //初始化date  
try {  
    date = sdf.parse(str); //Mon Jan 14 00:00:00 CST 2013  
} catch (ParseException e) {  
    e.printStackTrace();  
} 
//Date转换为String
    		Date date = new Date();
    		DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
    		String str = format.format(date); //2013-01-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lemon20120331

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值