苦心学习Php有一段时间了,仍然停留在入门初级阶段,仍然写不出自己的作品来,就算照着别人的现成的教材,一字不落的写在板板上,仍然会有层出不穷的错误,揪其因果,实乃版本之故。有位大虾,曾写下如下博文:

从PHP5.3开始加入了一个新的报错级别DEPRECATED,即将废弃/过期。

在php5.3被放弃的函数有:

call_user_method() //使用call_user_func()替代call_user_method_array() //使用call_user_func_array()替代define_syslog_variables()
dl()
ereg() //使用preg_match()替代ereg_replace() //使用preg_replace()替代eregi() //使用preg_match()配合'i'修正符替代eregi_replace() //使用preg_replace()配合'i'修正符替代set_magic_quotes_runtime() //以及它的别名函数magic_quotes_runtime()

session_register() //使用$_SESSION超全部变量替代session_unregister() //使用$_SESSION超全部变量替代session_is_registered() //使用$_SESSION超全部变量替代set_socket_blocking() //使用stream_set_blocking()替代split() //使用preg_split()替代spliti() //使用preg_split()配合'i'修正符替代sql_regcase()mysql_db_query() //使用mysql_select_db()和mysql_query()替代mysql_escape_string() //使用mysql_real_escape_string()替代mysql_close(); //将不支持全部关闭,需要改为:mysql_close($link);废弃以字符串传递区域设置名称.使用LC_*系列常量替代.

mktime()的is_dst参数.使用新的时区处理函数替代.

PHP 5.4:mcrypt_generic_end()
mysql_list_dbs()
PHP 5.5:mcrypt_cbc()
mcrypt_cfb()
mcrypt_ecb()
mcrypt_ofb()

其中,PHP 5.3是废弃函数的开始,很多常用的以前的正则ereg全部替换preg,但是魔术引号。居然也从PHP 5.3开始弃用,PHP 5.4就移除了。这个算是PHP 5.3的一个大变动吧。PHP 5.4开始新增了很多特性,新增很多特殊写法。(www.jbxue.com脚本学堂)

至于PHP 5.5,居然把MYSQL这个扩展去掉了,建议使用MYSQLI或者PDO!用了5.5很多程序都会报错,提示mysql_connect即将过期!!会看到如下错误:Deprecated: mysql_connect(): The mysql extension is deprecated and will beremoved in the future: use mysqli or PDO instead in E:testnew 6.php on line 6

PHP5相对于4的跨进最大的就是类的部分,而影响更多的就是废弃这些老习惯的东西吧。虽然版本一直在升级,但是终究市场上还是大量的5.1.6-5.2.17。5.3开始废弃很多特性,这就导致了很多程序也不敢直接上,5.5.直接秒杀了大量的开源产品!

现如今,能够在开源市场找到最新版的教程,屈指可数,或者根本没有,只能在旧版的教程基础之上勤加练习。昨天一段很简单的连接数据库操作的代码愣是把我搞得稀里哗啦的。代码如下:

mysql_connect("localhost","root","root");
mysql_select_db("exer");
$result=mysql_query("select * from wasa");
while($row=mysql_fetch_array($result,MYSQL_ASSOC)){
print_r($row);
echo "
\n";}
?>

好吧,够简单了吧,一目了然,无非就是要在数据库里面把数据以数组的形式取出并打印出来。可是,就这么简单的代码,在高于php 5.3版上一运行,出错了,报的错误搞的人晕头转向,虽然描述得很清楚,但却没有给出解决的方法。如下图所示:

在mysql中用于替代键的关键是哪个_PHP

将:mysql_connect()改为:mysqli_connect(),结果呵呵了:

在mysql中用于替代键的关键是哪个_PHP_02

你这错误,比我代码的行数还多,叫我情何以堪!

在mysql中用于替代键的关键是哪个_php_03

明明知道这个是PHP版本的问题导致的,可是如果是几千行,几万行的代码,因为版本的升级就死光光了,想想实在是令人恐怖的一件事。所以,那些在5.3版以前开发的网站或者管理系统,要升级的话,千万要三思后行了。其实,这段代码是没有问题的,下图是在windows server 2003系统上的WEB环境:

在mysql中用于替代键的关键是哪个_php_04

将代码中的数据库和表改动一下,运行的话是没有任何报错信息的,除了编码问题导致乱码外:

mysql_connect("localhost","root","root");
mysql_select_db("ecshop");
$result=mysql_query("select * from ecs_tag");
while($row=mysql_fetch_array($result)){
print_r($row);
echo "
\n";}
?>

运行结果:

在mysql中用于替代键的关键是哪个_mysql_05

处于菜鸟的心态,希望有大虾看到这篇小文章能够给予指点一二。