现在的位置: 首页 > 综合 > 正文

工作手记之潜规则篇

2013年07月23日 ⁄ 综合 ⁄ 共 654字 ⁄ 字号 评论关闭

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);  
    }  

 

抱歉!评论已关闭.