2011年12月

用Notepad++制作的名片

呵呵,网上看到的,自己一直在用Notepad++,顺便自己搞了个。

Notepad++做的名片

原地址:http://notepad-plus-plus.org/news/make-your-business-card-with-notepad-plus-plus.html

前台查询的结果字段不更新的问题排查

今天开发更新状态的一个功能,开发完后测试发现数据库里的字段值已经变了,但是前台仍显示的是以前的状态。
一开始以为是没更新成功,在数据库里仔细查了下确定是更改了状态,但是前台就是没有变化。
然后怀疑是前台查询的sql有问题,可能是没加相应的状态判断,于是文件里断点记录了下sql和查询结果,执行后发现sql没有问题,但是查询出来的结果里相应记录的状态没变。

呃,焦虑,这是什么情况啊...

接着怀疑是否是连错了数据库,不过这个直接被排除了,不可能的情况...

然后突然想到以前同事讲过的数据库缓存,于是搜索了下发现还真有这个功能。

MySQL cache功能分析:

1 MySQL的cache功能的key的生成原理是:把select语句按照一定的hash规则生成唯一的key,select的结果生成value,即key=>value。所以对于cache而言,select语句是区分大小写的,也区分空格的。两个select语句必须完完全全一致,才能够获取到同一个cache。

2 生成cache之后,只要该select中涉及到的table有任何的数据变动(insert,update,delete操作等),相关的所有cache都会被删除。因此只有数据很少变动的table,引入MySQL 的cache才较有意义。

使用场景:

MySQL的cache功能只适用于下列场合:数据变动较少,select较多的table。

执行下面的命令

show variables like '%query_cache%';

结果如下图:

可以看出来确实是开启了cache功能,但是这个缓存要求查询的sql必须要写SQL_CACHE,看了下php文件里并没有用到这个SQL_CACHE,应该不是这个缓存的,同样也排除了。

没办法,从最底层看吧。检查Mysql类文件,发现里面增加了memcache的处理,看了下代码,应该是memcache缓存了sql结果,至此困扰了快一下午的问题找到了原因。

周末电影分享《我们这一家》

很久没看电影了,最近确实太忙了,电影都没时间去看了。

今天看到优酷上推荐的这部电影,评分还蛮高的。
整部电影是以第三人称的方式来讲述故事的,古天乐和奶茶的演技都超棒,剧情不错,推荐一看。唯一我觉得瑕疵的地方就是长大后李天恩女儿的表演,不知道是不是国语版配音的问题,总觉得怪怪的。

剧情简介:

古天乐饰演的李天恩从小喜欢打架,后来成为了江湖老大。李天恩与奶茶饰演的陈美宝在警局里一见钟情,后来陈美宝有了李天恩的孩子,俩人因此结婚。
有了孩子的李天恩在一次社团火并中,突然意识到亲人的重要性,于是开始想脱黑。为了不让女儿知道自己黑社会老大的身份,李天恩开始了漂白的生活。

印象最深的一句台词:

张天恩用一分钟的时间加入了黑社会,却用了大半辈子的时间逃离。