仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1219|回复: 19
打印 上一主题 下一主题

[学习教程] PHP教程之周排行、月排行榜开辟总结(原创)

[复制链接]
爱飞 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-2-3 23:40:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
把例子全部敲进去试验,完成一遍以后就会有心得了,因为你会发现为啥我的程序和书上的一模一样就是结果不正确。新手学习的时候必须承认,不容易,因为我也是过来人,你会发现原来有那么多常用的语句,函数都要记。    准备常识:group by,MYSQL函数week()、month()
在设计数据库时普通都有一个字段来纪录文章的点击率,假如咱们要统计一周或一个月点击率排行光靠这一个字段是一定是没法完成的。这时候就要新建一个表,用来纪录每篇文章天天的点击率。 假定这个表名为ranking,界说四个字段:rid(表ID),contentid(与文章ID联系关系),hits(纪录天天点击率),date(工夫,主要,查询时作对照) ranking大致布局 id      contentid      hits      date 1       2                   12        2010-12-18 2       2                   23        2010-12-19 3       1                   15        2010-12-19 4       2                   21       2010-12-20 1、统计 第一步就是要纪录文章天天的点击率,这步十分复杂,当用户检查某篇文章时,PHP法式会停止一次数据库查询,判别是不是存在该笔记录,假如不存在,申明是当天第一次阅读该文章,需求拔出一笔记录,前面的访客再看这篇文章时,只需更新点击率就行。这就是纪录某篇文章一天的点击率。 PHP: $date = date("Y-m-d",time()); $contentid = $_GET[id];//以后文章ID $query = mysql_query("select * from ranking where contentid='$contentid' and date='$date'); //查询数据库 if($value = mysql_fetch_array($query)){     mysql_query("update ranking set hits = hits+1 where id='$value[id]' ");//假如有纪录,只需点击率+1 }else{     mysql_query("insert into ranking (`contentid`,`hits`,`date`) values('$contentid','1','$date')");//假如是第一次阅读,拔出一条数据,点击率为1 } 2、查询 此时统计任务已完成,接上去要把这些文章按一周或一个月点击率总和的按次查询出来,这是个难点。 1.先要给文章分组并盘算总点击率:select *,sum(hits) from ranking group by contentid order by sum(hits) desc 2.取本周数据挑选出来:select *,sum(hits) from ranking where week(date)=week(now()) group by contentid order by sum(hits) desc 这是周排行的查询语句,绝对对照庞杂,查询出来后再放到数组中顺次显示出来,月排行也是如许,换一下函数就行,完全的PHP代码我就不写出来了。   http://bbs.php100.com/mode.php?m=o&q=user&u=53700 <P style="TEXT-INDENT: 2em">
怎么培养啊 别光说不练啊,好 ,比如新人入门自己步是配置环境,虽然现在都有很多的集成环境,但是真实的体验下配置环境还是会有很多帮助,不论是你以后工作还是在真实的linux下开发。
不帅 该用户已被删除
沙发
发表于 2015-2-4 05:07:22 | 只看该作者
真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎,
莫相离 该用户已被删除
板凳
发表于 2015-2-5 23:54:41 | 只看该作者
不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。
蒙在股里 该用户已被删除
地板
发表于 2015-2-6 13:59:08 | 只看该作者
写js我最烦的就是 ie 和 firefox下同样的代码 结果显示的结果千差万别,还是就是最好不要用遨游去调试,因为有时候遨游是禁用js的,有可能代码是争取结果被遨游折腾的认为是代码写错。
小魔女 该用户已被删除
5#
发表于 2015-2-16 09:34:06 | 只看该作者
写js我最烦的就是 ie 和 firefox下同样的代码 结果显示的结果千差万别,还是就是最好不要用遨游去调试,因为有时候遨游是禁用js的,有可能代码是争取结果被遨游折腾的认为是代码写错。
再见西城 该用户已被删除
6#
发表于 2015-3-4 06:08:43 | 只看该作者
开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。
只想知道 该用户已被删除
7#
发表于 2015-3-11 03:15:55 | 只看该作者
刚开始安装php的时候,我图了个省事,把php的扩展全都打开啦(就是把php.ini 那一片 extension 前面的冒号全去掉啦),这样自然有好处,以后不用再需要什么功能再来打开。
乐观 该用户已被删除
8#
发表于 2015-3-11 03:22:54 | 只看该作者
对于懒惰的朋友,我推荐php的集成环境xampp或者是wamp。这两个软件安装方便,使用简单。但是我还是强烈建议自己动手搭建开发环境。
柔情似水 该用户已被删除
9#
发表于 2015-3-17 01:08:02 | 只看该作者
这些中手常用的知识,当你把我说的这些关键字都可以熟练运用的时候,你可以选择自己
透明 该用户已被删除
10#
发表于 2015-3-17 08:09:19 | 只看该作者
再就是混迹于论坛啦,咱们的phpchina的论坛就很强大,提出的问题一般都是有达人去解答的,以前的帖子也要多看看也能学到不少前辈们的经验。别的不错的论坛例如php100,javaeye也是很不错的。
小妖女 该用户已被删除
11#
发表于 2015-3-24 02:45:17 | 只看该作者
因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax
兰色精灵 该用户已被删除
12#
发表于 2015-4-17 20:53:18 | 只看该作者
装在C盘下面可以利用windows的ghost功能可以还原回来(顺便当做是重转啦),当然啦我的编译目录要放在别的盘下,不然自己的劳动成果就悲剧啦。
因胸联盟 该用户已被删除
13#
发表于 2015-4-21 23:14:03 | 只看该作者
因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax
分手快乐 该用户已被删除
14#
发表于 2015-4-22 08:42:55 | 只看该作者
实践是检验自己会不会的真理。
小女巫 该用户已被删除
15#
发表于 2015-4-26 16:47:25 | 只看该作者
没接触过框架的人,也不用害怕,其实框架就是一种命名规范及插件,学会一个框架其余的框架都很好上手的。
谁可相欹 该用户已被删除
16#
发表于 2015-4-26 18:12:07 | 只看该作者
个人呢觉得,配wamp 最容易漏的一步就是忘了把$PHP$目录下的libmysql.dll拷贝到windows系统目录的system32目录下,还有重启apache。
冷月葬花魂 该用户已被删除
17#
发表于 2015-4-29 16:58:10 | 只看该作者
学习php的目的往往是为了开发动态网站,phper就业的要求也涵盖了很多。我大致总结为:精通php和mysql
18#
发表于 2015-5-10 18:10:27 | 只看该作者
再就是混迹于论坛啦,咱们的phpchina的论坛就很强大,提出的问题一般都是有达人去解答的,以前的帖子也要多看看也能学到不少前辈们的经验。别的不错的论坛例如php100,javaeye也是很不错的。
简单生活 该用户已被删除
19#
发表于 2015-6-6 04:15:06 | 只看该作者
说php的话,首先得提一下数组,开始的时候我是最烦数组的,总是被弄的晕头转向,不过后来呢,我觉得数组里php里最强大的存储方法,所以建议新手们要学好数组。
若相依 该用户已被删除
20#
发表于 2015-6-13 16:47:27 | 只看该作者
使用 jquery 等js框架的时候,要随时注意浏览器的更新情况,不然很容易发生框架不能使用。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-24 02:43

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表