免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 799 | 回复: 0
打印 上一主题 下一主题

PHP+MySQL扎实基本功 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-10-10 20:29 |只看该作者 |倒序浏览

一. 10句话
1.不要依赖register_global=ON的环境,从你刚懂得配置php运行环境甚至尚不明白register_global的ON/OFF会对自己有什么影响的那天起,就应该勇敢地把它设为OFF.
2.写程序前看看怎么用error_reporting.
3.不懂就问本身没错,但你需要在那之前查查手册。
4.当然,你需要懂得使用手册。手册上找不到答案的时候,应该考虑下网络上的搜索引擎。
5.刚学会php+mysql之后,不要叫嚷着要写论坛,要写XXX。要明白,刚学会写汉字并不表示你有能力写诗。
6.在学web编程的时候,你应该先去认识html这个朋友。
7.有点能力后,试着回答新手的问题,不要看到自己懂的而别人不懂就沾沾自喜,扔下一名“简单,那是基本的东西”就走更要不得。
8.思考是一个好习惯,不动手去写就等于空想,什么也没有。
9.写好一段程序,如果觉得很满意,一周后再看一遍,也许你会认为它应该有所改变
10.有空多看看别人的程序,找出他人的不足或优点,自己掂量。
二. 各取所需
1.善于使用“引用”,它能直接影响到程序的效率。
2.善于用三元运算子,可以让程式较精简有效率。
比如:
PHP代码:
if ($data[$i]['nickname']){
    $nickname =  $data[$i]['nickname'];
}
else{
    $nickname =  $data[$i]['ip'];
}
可以写成:
PHP代码:
$nickname =  $data[$i]['nickname'] ? $data[$i]['nickname'] : $data[$i]['ip'];
3.善于组织if...else...回圈
比如:
PHP代码:
$ext_name = strtolower(str_replace(".", "", strrchr($upfilename, ".")));
if (!empty($type))
{
    if (!strpos($type, $ext_name))
    {
        echo "Please upload the file of $type form.";
        exit();
   }
}
上面的代码你应该写成这样:
PHP代码:
$ext_name = strtolower(str_replace(".", "", strrchr($upfilename, ".")));
if (!($type==='') && strpos($type, $ext_name)===false)
{
    echo "Please upload the file of $type form.";
    exit();
}
4.尽量让你的代码清淅些,如果写成这样,是比较让人头痛的:
PHP代码:
$foo=$_post["foo"];
   $username=$_post["user"];
$group=$_POST["group"];
if ($group=="wheel")
{
$username=$username."wheel";
}
同样的代码,这样就比较让人看得舒服了:
PHP代码:
$foo      = $_post["foo"];
$username = $_post["username"];
$group    = $_POST["group"];
if ($group=="wheel")
{
    $username = $username."wheel";
}
当然,有一定基础后,你应该要写成这样:
PHP代码:
$foo      = &$_POST['foo'];
$username =  $_POST["group"]!='wheel' ? $_POST["username"] : $_POST["username"].'wheel';
5.编写规范的mysql 语句。
字段和表名用"`"引起来,避免保留字的影响。
如果看到下面这样的一个sql query,会让人比较头痛:
PHP代码:
$query="select `
flash
_comment`.`content` , `
flash
_comment`.`nickname` , `
flash
_comment`.`date` , `
flash
_comment`.`ip` , `product`.`p_name` , `sg
flash
`.`fid` from `
flash
_comment` left join `product` on ( `
flash
_comment`.`p_no` = `product`.`p_no` ) left join `sg
flash
` on ( `product`.`p_name` = `sg
flash
`.`f_name` ) where `
flash
_comment`.`p_no` != '' order by `
flash
_comment`.`date`";
同样的一个query,写成这样就令人看得明白得多了:
PHP代码:
$query = "SELECT `
flash
_comment`.`content` , `
flash
_comment`.`nickname` , `
flash
_comment`.`date` , `
flash
_comment`.`ip` , `product`.`p_name` , `sg
flash
`.`fid`           FROM `
flash
_comment`           LEFT JOIN `product` ON ( `
flash
_comment`.`p_no` = `product`.`p_no` )           LEFT JOIN `sg
flash
` ON ( `product`.`p_name` = `sg
flash
`.`f_name` )           WHERE `
flash
_comment`.`p_no` != ''          ORDER BY `
flash
_comment`.`date`";


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/23879/showart_182360.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP