工作手记之潜规则篇

1.mysql的timestamp中的一些潜规则

TIMESTAMP列的默认值是CURRENT_TIMESTAMP常量值。当记录数据发生变化的时候,TIMESTAMP列会自动将其值设定为CURRENT_TIMESTAMP。(可以自动更新时间了,不错)

一个表可以存在多个TIMESTAMP列,但只有一个列会根据数据更新而改变为数据库系统当前值。(当一个表有两个字段都需要自动更新时间,这么做就坑爹了。推荐使用datetime)

不指定not null时,timestamp默认是not null的,所以不能default为null

注意:datetime不指定not null时,默认为null,和timestamp有点区别

 

2.Integer的缓存,你知道么?

public static void main(String[] args) {
        System.out.println(Integer.valueOf(300) == Integer.valueOf(300));
        System.out.println(Integer.valueOf(3) == Integer.valueOf(3));
    }

知道结果是什么不?

false
true

为嘛呢?

public static Integer valueOf(int i) {  
    final int offset = 128;  
    if (i >= -128 && i <= 127) { // 这里开始坑爹了。。。。原来是有缓存的 
        return IntegerCache.cache[i + offset];  
    }  
        return new Integer(i);  
    }  



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值