java.util.Date 和 java.sql.Timestamp的区别

在Java中,`java.util.Date`和`java.sql.Timestamp`是两个表示日期和时间的类,它们有一些区别:

1. `java.util.Date`:
   - `java.util.Date`是Java中较早引入的日期和时间类。
   - 它用于表示日期和时间,包括年、月、日、时、分、秒等信息。
   - `java.util.Date`在Java 8及之前广泛使用,但在Java 8之后,它被弃用了。

2. `java.sql.Timestamp`:
   - `java.sql.Timestamp`是Java中专门用于表示SQL数据库中的日期和时间类型的类。
   - 它继承自`java.util.Date`,因此也包含了年、月、日、时、分、秒等信息,但比`java.util.Date`更精确。
   - `java.sql.Timestamp`在Java 8及之后仍然可用,并且建议在与数据库交互时使用它。

主要区别在于精确度和用途:
- `java.util.Date`的精确度是毫秒级别,对于大多数情况来说足够了,但在数据库交互时可能会引起一些问题。
- `java.sql.Timestamp`继承自`java.util.Date`,精确度更高,可以表示纳秒级别的时间戳,适用于与数据库进行精确时间匹配。

如果你需要在Java中处理日期和时间,尤其是在与数据库进行交互时,推荐使用`java.sql.Timestamp`,或者更好地,考虑使用Java 8中引入的`java.time`包中的新日期和时间API(如`java.time.LocalDateTime`、`java.time.Instant`等),它们提供了更好的API设计和更高的精确度。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
package com.hexiang.utils; /** * SQLUtils utils = new SQLUtils(User.class); utils.setWhereStr("", "id", "=", 100).setWhereStr("and", "name", " ", "is null").setWhereStr("and", "date", ">=", new Date()); utils.setOrderByStr("id", "desc").setOrderByStr("name", "asc"); System.out.println(utils.buildSelectSQL()); System.out.println(utils.buildCountSQL()); */ import java.sql.Timestamp; import java.text.SimpleDateFormat; import java.util.Date; import java.util.LinkedHashMap; import java.util.LinkedList; import java.util.List; import java.util.Map; public class SqlUtils { private String beanName; private String beanShortName; private Map propertyMap; private List conditionList; private List relationList; private Map orderByMap; public SqlUtils(Class instance) { this.setBeanName(instance.getSimpleName()); this.setBeanShortName(Character.toLowerCase(this.getBeanName() .charAt(0)) + ""); init(); } public SqlUtils() { init(); } void init(){ propertyMap = new LinkedHashMap(); conditionList = new LinkedList(); relationList = new LinkedList(); orderByMap = new LinkedHashMap(); } /** * 添加查询条件 * * @param relation * 关联 "and","or"等 * @param property * 查询的对象属性 * @param condition * 查询的条件,关系符 * @param value * 查询的值 */ public SqlUtils setWhereStr(String relation, String property, String condition, Object value) { if(value != null){ relationList.add(relation); propertyMap.put(property, value); conditionList.add(condition); } return this; } private String buildWhereStr() { StringBuffer buffer = new StringBuffer(); if (!propertyMap.isEmpty() && propertyMap.size() > 0) { buffer.append("WHERE 1 = 1 "); int index = 0; for (String property : propertyMap.keySet()) { if (property != null && !property.equals("")) { buffer.append(r

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值