不得不说,有时候GOOGLE确实比较方便,在finance.google.com刚刚推出的时候,GOoGLE就推出了一个短信查询股票的功能,只是后来。。。好象改了一个很长的服务号码,就被我直接忽略掉了,实在记不住。
如今,google sms alert又推出一个比较人性化的功能,即,在aoyun期间,针对你喜欢的项目,在比赛后大约两小时内给你发送免费短信。免费的哦。你可以自由订阅,网址是:http://www.google.com/sms/alerts,可能需要你事先注册一下你的手机号,很方便。我是一下子就收到短信了。
听说这个平台是google与腾讯合作的,经常收腾讯短信的人,如果看到号码与腾讯相仿,千万不要紧张。
至于是否真的要钱,则看谷歌移动支持中心,里面有详细的解释,特别是:该服务如何收费?,当然,订阅多了的话,也需要看:我订阅了多种内容,如何管理这些短信提醒?,不过,不是每个人的手机都支持的,不过在中国应该是都可以的,比方说我的手机号码是否支持订阅?呵呵
希望aoyun期间能够收到令人振奋的消息。不过我不是很期待。。。
经常在使用MYSQL,那么总是有一些小技巧的,我在这里稍稍介绍一点,这也是日常工作中常用到的。
1、尽量在SQL中对字段使用函数(条件部分)
在WHERE条件中,对字段使用函数的时候,往往就自动放弃了该字段的索引值了。举例:
SQL代码
- SELECT * FROM order WHERE YEAR(OrderDate)<2001;
-
- SELECT * FROM order WHERE OrderDate<"2001-01-01";
第二句会比第一句快很多,数据少可能看不出,数据量超过50W以后将非常明显。
2、尽量在SQL的条件中先取值再比较
SQL代码
- SELECT * FROM inventory WHERE Amount/7<24;
-
- SELECT * FROM inventory WHERE Amount<24*7;
虽然取回来的值都一样,但是。。。第一句是拿字段中的值先进行计算,再比较大小,而第二句却仅仅比较大小,谁快谁慢,一眼便知。
3、在搜索字符型字段时,我们有时会使用 LIKE 关键字和通配符,这种做法虽然简单,但却也是以牺牲系统性能为代价的。(这个我自己没有测过,不能乱讲)。。。
例如下面的查询将会比较表中的每一条记录。
SQL代码
- SELECT * FROM books WHERE name like "MySQL%"
但是如果换用下面的查询,返回的结果一样,但速度就要快上很多:
SQL代码
- SELECT * FROM books WHERE name>="MySQL"and name<"MySQM"
4、应该注意避免在查询中让MySQL进行自动类型转换,因为转换过程也会使索引变得不起作用。
5、为字段选用最恰当的属性
MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的 查询也就会越快。因此,在创建表的时候,为了获得更好的性能,我们可以将表中字段的宽度设得尽可能小。例如,在定义邮政编码这个字段时,如果将其设置为 CHAR(255),显然给数据库增加了不必要的空间,甚至使用VARCHAR这种类型也是多余的,因为CHAR(6)就可以很好的完成任务了。同样的, 如果可以的话,我们应该使用MEDIUMINT而不是BIGIN来定义整型字段。
另外一个提高效率的方法是在可能的情况下,应该尽量把字段设置为NOT NULL,这样在将来执行查询的时候,数据库不用去比较NULL值。
对于某些文本字段,例如“省份”或者“性别”,我们可以将它们定义为ENUM类型。因为在MySQL中,ENUM类型被当作数值型数据来处理,而数值型数据被处理起来的速度要比文本类型快得多。这样,我们又可以提高数据库的性能。
6、使用命令复制表时,请先禁止源表中的索引,因为在COPY的过程中,MYSQL会同样复制索引,而不是复制数据后重建索引,因此建议COPY前先禁用,然后COPY完后,为目标表添加相应的索引。
本文来自天极网,但具体网址没有了,因为别人也是转摘,唉。如果有需要,请告诉我链接,我会加上,或者通知我删除本文。谢谢。
原文摘要:
本文将讨论多态性的概念及其在面向对象设计中的应用,还将分析如何在php5中使用多态性以及存在的优缺点。
PHP的最新发行版本中已经实现了对迟绑定的支持。当然,在使用其迟绑定功能时还存在很多问题。如果你使用的是更旧版本的PHP(我的服务器上运行的是 PHP 5.0.1版本),那么你可能发现其中缺乏对于迟绑定的支持。因此,请注意本文中的代码有可能无法工作在你特定的PHP 5版本中。
» 阅读全文
在工作中我总是会发现有些人的程序里有些不妨碍程序正常执行的小问题,并且很多人都常常愿意这样写,下面我列举一下
1.php属于弱语言,所以在使用一个变量的时候,不需要为其指定变量类型和初始化值,但是我强烈建议在使用一个变量前,先为其初始化一个默认值,这样既安全又规范
2.
if (条件表达式1 && 条件表达式2)
//do something
else
//do something
?>
当进行与运算操作的时候,最好把最可能返回"False"的表达式放在操作的前面,这样当if条件遇到false后,就不在执行false以后的运算了,这样加快程序的执行速度,但是要注意一点的是false以后的条件表达式如果是个赋值的表达式,例如:
$a = 1;
$b = 0;
if (($a > 1) && ($b = 2))
?>
这段程序在$a > 1这个地方就执行完了,$b = 2的赋值操作将不再执行,结果$b的值还是0.
3.在使用mysql数据库的时候,执行"select count"操作的时候,尽量使用count(*)而不是count(一个字段),count(*)会直接使用索引文件进行统计(inndb类型的表除外)而不是去遍历整个数据表
4.在使用group by的时候,如果没有必要对返回结果集合进行排序,建议加上"order by null",这样会减少一步排序的操作
5.为table建立复合索引的时候,比如"name-city-age"这个索引,这个索引是由表中的字段name,city,age组成的,虽然我们 只为这张表建立了一个索引,但其实...嘿嘿嘿...这是三个索引,恩,哪三个索引呢...name,name-city,name-city-age这 三个索引,请注意,复合索引遵循的是最左原则,所以name-age,city-age将不会使用索引...
6.在建索引的时候,如果能保证这个(复合)索引的字段(组合)的值肯定是唯一值,那么就把这个(复合)索引建成唯一索引...
取自abetterday的博客:http://www.phpwap.cn/?action=articleContent&articleId=153