java获取时间戳的方法

今天在设计表时需要用到一个时间戳字段方便做乐观锁,而且时间戳这个字段也是挺实用的!
百度了一下有三种,我就说一下自己用的!

public class DateUtil {
    public static String getTimestamp(){
        return new SimpleDateFormat("yyyyMMddHHmmssS").format(System.currentTimeMillis());
    }
}

因为系统获取的System.currentTimeMillis()是毫秒数,所有需要转成自己想要的格式,我精确到毫秒是以后可能并发会用到!

之前微信公众号看到过一个并发用的方法,我忘记了!可恶啊!书到用时方恨少,下次再看到一定更新到这里来!

对了,问大家个问题,时间戳你们是选择一个单独的时间戳,还是根据操作分成新增/修改/删除呢?

时间戳你们用的什么类型,是bigint还是varchar还是timestamp?

经过我与群里的大佬们一番商量,我选择把上面那个时间戳转成long类型,然后数据库里设为bigint。

public class DateUtil {
    public static long getTimestamp(){
        return Long.parseLong(new SimpleDateFormat("yyyyMMddHHmmssS").format(System.currentTimeMillis()));
    }
}

但是我又感觉不太好,毕竟是强转,虽然说这个生成的绝壁是long类型。

要不要用数据库用timestamp?然后java这边直接System.currentTimeMillis()获取后直接传过去。

然后要从数据库读出来当时间用的时候,再转成各种各样的日期类型?

看了一下数据库用timestamp,我java这边就得转成日期型再传过去,不是很满意!

### Error updating database.  Cause: com.mysql.cj.jdbc.exceptions.MysqlDataTruncation: Data truncation: Incorrect datetime value: '1619071627313' for column 'operate_timestamp' at row 1

如果我是传毫秒数的话也要13位,所有我打算就传17位一长串的yyyyMMddHHmmssS的这种,直接看数据都很方便!

所有最后的结果就是java这边用long,数据库用bigint!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值