为客户做一个导入功能,其中有一个需求,客户中有一个媒体字段,导入后要根据导入客户的媒体,查出媒体的一些数据更新到这个客户的字段中。
测试导入功能没有问题,便交付了,过不多久,客户反映速度有点慢,再查原因,发现和查出媒体的一些数据有关,虽然sql语句执行时间很短,但是由于导入数据量很大,每一次都要执行,导致了时间延长了。
接下来就是想利用“缓存”技术解决了,分析如下:
1.导入的客户巨大,但是客户的媒体很多都是重复的,许多sql语句是重复执行的。
2.由于媒体的信息更新的,但是可以认定本次访问中相同媒体获得的数据相同,所以这次的缓存的有效时间只是本次连接时间。
3. 缓存的速度要尽可能的快。众所周知,不同的缓存的速度是不同的,本地内存>memcache>磁盘缓存。
而这三个特点,可以使用static变量来实现缓存。
代码基本形式如下:
static变量实现缓存的优缺点:
优点:
速度快,效率高,实现简单。由于是PHP内部变量,是所有缓存中执行效率最高的。
缺点:
灵活性差,只在本次连接中有效,执行区域小,只在同一个函数中有效,无法跨函数运作(可以使用全局变量替代)。
总结:static变量做缓存非常好用,而且耗费的资源不多,对于要查询数据库的,且在一次连接中可能执行多次的,不妨加上。虽然可能效果有限。