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