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