使用mysql中的with rollup可以得到每个分组的汇总级别的数据:
表如下:
1 | CREATE TABLE `test3` ( |
使用mysql中的with rollup可以得到每个分组的汇总级别的数据:
表如下:
1 | CREATE TABLE `test3` ( |
MySQL中存在float,double等非标准数据类型,也有decimal这种标准数据类型。
其区别在于,float,double等非标准类型,在DB中保存的是近似值,而Decimal则以字符串的形式保存数值。
float类型是可以存浮点数(即小数类型),但是float有个坏处,当你给定的数据是整数的时候,那么它就以整数给你处理。这样我们在存取货币值的时候自然遇到问题,我的default值为:0.00而实际存储是0,同样我存取货币为12.00,实际存储是12。
幸好mysql提供了两个数据类型:numeric和decimal,这两种数据类型可以轻松解决上面的问题:NUMERIC 和 DECIMAL 类型被 MySQL 以同样的类型实现,这在 SQL92 标准中是允许的。他们用于保存对准确精度有重要要求的值,例如与金钱有关的数据。
今天在看CU的时候,发现有人问有关optimize来表优化的问题,当年因为这个问题,困扰我很长一段时间,今天有空我把这个问题,用实际数据来展示出来,让大家可以亲眼来看看,optimize table的重要作用,而不是似是而非的估计了。
1,数据量
1 | mysql> select count(*) as total from ad_visit_history; |
2,存放在硬盘中的表文件大小
1 | [root@BlackGhost test1]# ls |grep visit |xargs -i du {} |
问题背景:
在填写完表单提交时,由于某个表单项可能填写的不合法,导致提交失败,返回表单页面。但返回后所有的表单都被清空了,重新填写比较麻烦,度娘解释说,是由于每个页面都调用了session_start()的原因,在js返回上一页时,不能保存住表单信息。
解决方法:
在公共初始化文件的session_start()之后加入一句:
header(‘cache-control:private,must_revalidate’)
或:
session_cache_limiter(‘private’)
PHP的json_decode无法解析的JSON数据,代码如下:
1 | $json = "{rst:5,c:[ [1018485,2,0,0,0,0,'','0-0','','',2,0,2],[1049809,17,0,0,0,0,'','','','',1,0,1],[1049813,17,0,0,0,0,'','','','',1,0,1],[1049810,17,0,0,0,0,'','','','',1,0,1]],fn:135388}"; |
//结果输出: null