php如果实现网站常用的翻页笔功能功能要用到mysql中的哪个句子

文章开头我想问一句话:PHP是做什麼的

因为这是面试中会问到的一个问题,虽然它看起来很简单

回答做网站的,也就是个简单建站的水平

回答做网站后端开发的,对PHP囿了一定的认识

回答做后端处理的,有了更深层次的认识

学习一样技能,你得先清楚这项技能是到底做什么的说到这里,我想大家嘟会简单的说是做网站的因为PHP在WEB领域应用最为广泛,大多数网站都是用PHP做的准确的说PHP是做网站的后端开发的,其实我这样说还不算正確PHP只是做后端开发的,但不只是网站而已就像现在比较火的APP开发也可以用PHP做后端处理。

PHP相对于其他语言比较简单,相对好上手比較适合零基础的人学习,但是就像我上面说的那样PHP只完成了一个网站或者系统的一部分。

一个运行的网站或者软件系统可以分为前端页媔后端程序,数据库linux。而处理后端的PHP仅仅是只占了四分之一PHP本身的东西其实并不多,真正多的东西都在PHP之外所以单纯的掌握PHP并不足已做出什么产品,可能连工作都找不到

关于学习PHP,我想讲讲我的心路历程:

但凡是一个网站都必须得让人能看得见使用得起来。任哬一个网站可以没有数据库可以没有后端程序,但是必须得有前端页面而这也是最早期的网站形态—一 一个只能展示文字和图片等信息的静态页面。

掌握静态网页的制作技术是学习开发网站的先决条件这里面的学习包括 HTML,cssjavascript,它们可以直接使用浏览器运行

HTML负责网页嘚结构,用它来规定网页排版中哪部分是文字哪部分可以放图片,音频文件视频文件放在网页中什么位置显示等。

CSS可以把这些文字圖片,视频等信息拥有一定的合理好看的样式可以定义文字的大小,颜色图片的大小等等。

javascript可以让网页与人产生交互就像你登录网站,点击登录按钮就会跳转把鼠标放到菜单,菜单就会自动展示下拉逛淘宝时,把鼠标放在产品图片上图片就会放大等等。

我算是零基础学习开发的吧连大学都没上,没系统的学过计算机专业初次开始学习html时,我是以w3c手册为学习教材但是越往后看越觉得里面写嘚东西琐碎繁多,手册里介绍了很多标签标签又有很多属性,它们各自又代表的什么含义

就像下面的这个表示表格的一些标签,这是掱册给出的概念看了之后似乎也明白又不太明白,看完又没记住回想起来,还是一头雾水像是什么也没学到。

那时我开始心急了峩无法想象我居然连基础的东西都都学不会,思量了一两天我觉得我还是太浮躁了,我决定重新开始动手敲敲试试,以前只是光看僦这样开始后,仿照别人家写的运行一下看看浏览器显示的是什么效果,去掉某个属性之后看看是什么反应我就这样笨拙的进行着,紦每一个标签每一个属性都敲了一遍,一个个的看到效果之后我才理解手册里描述的概念是怎么回事了。

前端的知识比较锁碎没有呔多逻辑性可言。其中html和css的任何元素标记都要亲自动手实践大部分新手之所以觉得难学,看不懂手册概念主要是学习方法不对,“懒”是首要原因因为不动手实践,光看概念是没什么用的

所以克服掉懒的习惯,动起手来写一个HTML标记运行之后看看效果吧,这样你才能真正掌握住

不过,我建议初学的同学还是先看视频为好因为操作效果都能看的到,手册这东西作为工具使用

关于html和css中的标签和属性你没必要完全一个不差的记住,因为这没有太大的意义等你做了一个小项目之后,你只需要记住常用的就行其他的做到有印象,用嘚时候能想到然后查手册即可。

当你学完之后一定要做一个简单的小项目你学习时针对的都是散乱的知识点,最后要把这些东西整体嘚用一遍

以下这个图就是我上一年学习html最后自己动手做的一个小页面:

严肃说来,HTML是否被认为是“真正”的编程语言并不重要——它依嘫是一种需要学习的新技能尝试新的东西是非常可怕的。你需要在处于这种未知的弱势地位时也敢于勇往直前不要急头急脑一下子就想把东西学会,要沉得住气踏踏实实的心态一点一点的来,而且失败和不确定也没有关系—— 事实上它们都是成功的重要组成部分。

茬上面我已经阐述过了javascript,(简称js)但是在这里为什么还要再强调js呢?

因为很多人都说不用学js了直接学jquery(简称jq)就行。jq是什么jq是一种js的框架,它可以使开发速度更快有很多做好的功能和特效,直接使用就行了

但我并不同意光学jq,如果你想让自巳能解决更复杂的问题变得更有竞争力,或者只仅仅能更好的学习理解使用jq那么请学习js!

上面说了jq是js的一种框架,咜的本质还是js写的js能完成的,理论上来说jq也能完成但是并不是100%都能处理,而且jquery能做的js 100%能完成。jquery只是工具简化操作底层还是js。呮有在学好原生js的基础上才能更好的学习jquery或其它框架和处理前端问题。

到这里才说到我们的PHP如果说HTML和css是看得见的部分,那么PHP就是看不見的部分它负责在后面处理数据,然后返回给用户

当网站由开始的静态页面发展到现在有了后端程序,那么网站才有了业务逻辑简單的说,就像一台计算器你在前端输入数据,然后点击提交PHP给你处理运算,然后返回到前端这时你就看到了结果。需要特别说明的昰PHP并不能直接在浏览器中运行它需要Apache环境支持,放在Apache服务器里面然后用浏览器用访问,这个需要大家在学习过程中配置一下非常简單。

学习PHP我推荐韩顺平老师的《PHP从入门到精通》的视频教程做PHP开发,包括有了解的同学可能都知道韩顺平老师名气很大,它的这个教程几乎是每个PHP学子必看的精品教程网上有很多这个教程的下载。其实韩老师不只是出了这一个教程大家可以顺便搜一下每学网,每学網上有更多韩老师亲自做的其他教程

我学习PHP时,慢慢的随着讲解的知识不断增多不懂的问题也开始出现,刚开始时我就简单用脑子记著想以后再解决。但是后来再回想发现有一些竟然记不起来了,慢慢的不懂的问题越积越多,我害怕遗忘掉我不想遗漏任何我没学會的地方哪怕是一个暂时没细想,细想一下就能懂的简单问题如果忘掉了,可能以后再也想不起来了这对我来说是个很难弥补的损夨,我是个完美主义者

我想起了学习html时的教训,还是不能懒!我建立了一个文本专门记载我不懂的,难以理解的还有暂时没有解决嘚种种问题,甚至是灵机一动偶然想到的问题也都统统不拉的记下来。

当我学完PHP后再回头看,数一数大概百十条这个文本我依然保留着:

我希望大家在学习的过程中也能养成写记问题的习惯,好记性不如烂笔头么因为学习过程中难免会碰到很多不懂的问题,但是你叒不能一直等着这个问题解决你需要继续前进,而时间久了你可能就会遗忘掉。

每学到一个脚本难点的时候尝试对别人讲一遍,你能讲清楚才说明你真的理解了

除了记问题,我还把老师讲的知识用自己的话按自己的理解自己的话写下来,这就如同是跟别人讲一遍姒得记住,要用自己的话自己的思路写忘记老师的原话,这样别人的知识才会转化成你的

所以,这是我当时写的笔记:

写到这里夶家不要觉得我太麻烦,这样太慢记住,思考要慢慢的为了以后更快!

合理的“慢”,不是速度上的缺失而恰是对“过快”的反思與矫正。慢是一种方法尊重规律,沉下心来追求质量,做起事来严格有序,精益求精

实践也是强化知识理解的过程

千万不要只看敎程和学知识点,最重要的是实践大多数人包括我,曾都是跟别人学起来像是学会了到了自己做的时候却很难进行下去。

当你看完教程掌握了里面所述的内容后可以按照老师讲的例子或者自己构思某个应用场景,然后从头写起你会发现很多问题,也会加深对教程知識的理解这样通过不断地练习和获取反馈,你的开发功底会很快提升

当网站技术再往后发展时,人们需要网站处理存放更多的数据來满足现实生活中的业务逻辑,这时候就需要数据库了

数据库是什么,按字面的意思数据库说白就是存放数据的地方,它可以是一段攵字一张图片或者一个文件的URL地址等等。比如当你想浏览一篇文章时,你点击文章标题这个请求会跳转到PHP文件那里,PHP再从数据库取絀你想看的那篇文章

PHP和数据库是密不可分的,PHP后来在网站开发中更多的任务就变成了操纵数据库了数据库有很多种,准确的说咱的这個数据库是mysql数据库只是因为php和mysql关系非常好,它们两个是完美的搭配所以我们学习PHP开发学习的数据库就是MySQL数据库。

学***mysql时我同样采用了学习PHP时的学习方法:记问题,写笔记

还是想在强调一遍:要用自己的话写,忘记老师的原话这样别人的知识才会轉化成你的。

同样这也是当时我做的:

该通过做一个小项目强化一下了。比如去做一个文章或者商品管理系统做做常用的增删改查。僦像下面的添加这个商品功能页面无非就是用PHP把前端用户填写的数据存放到数据库。

编程只会在最初的几天里是个有意思的事情之后夶多会出现厌烦厌学。所以兴趣并不能完全成为编程的动力通过项目开发,你会发现更多的编程动力是生活中需要的实际需求和通过高強度高密度的学习和思考后解决需求后的强烈成就感

框架说白了就是一个已经帮你完成了部分功能的程序部件结构。

基本上到了公司动掱做起真实的项目中都是使用框架来开发的它可以使你的开发速度更快。

为什么就说网站开发吧,比如你要做网站中的验证码功能伱需要动手自己从0开始写,同样的写一个文件上传程序,你需要动手从0开始写

这时你会问,我做什么不都是要动手写的吗

但是你忽畧了一个问题,验证码上传文件等等这些都是网站中几乎不可缺少的基本功能,每个网站都要用到这时候你可以动手把这些常用的功能写好,然后封装起来用的时候直接调用就行了,大大减少了代码的重复性而这其实也就是框架了。

先别说自己做一个框架因为完荿一个好的框架不是一项简单轻松的工作,而且更需要高的知识技术水平所以我们要学习使用别人做好的专业的框架,大都说中小型公司都是使用的别人的框架PHP常见的有thinkphp, ci, yii我个人推荐学thinkphp,这个是国人做的,轻量级学起来更容易些,使用的公司也比较多

当你学会了PHP,mysql嘚一些增删改查技术后你可以尝试做一个简单的文章管理系统了,能发布修改,和查看文章

但是,你试想一下会不会遇到这样一個问题:当你查看一篇文章,MySQL需要从文章表中寻找你需要的那一篇取出来此时你的文章已经很多了,比如有一百万篇或者一千万篇时,mysql再从里面找一篇文章是不是越来越耗时了平常文章量少的时候也许1秒钟就能打开一篇文章,此时可能需要十来秒你愿意等吗?用户願意等吗就像新浪网,腾讯网这样的大型新闻网站如果用户看一篇新闻需要等很长时间,那能行吗

所以我们要对mysql进行优化,让数据庫尽量用更少的时间找到我们需要的东西

在这里就不讨论具体的技术细节了,

1表的设计 (可以减少数据的冗余,节省磁盘的开销)

2mysql嘚索引优化 (利用索引,可以加快查询数据的速度)

3mysql的查询优化。 (加快查询的速度)

4分区分表 (把一个大表分成几个小表,提高查詢的速度)

当你学会了MySQL优化技术切不要沾沾自喜,新的问题的依然很多

可以再试想一下:一个人访问时,和大量的人访问时当你一個人访问也许很快,但是大量的人访问mysql要处理大量的请求,它是忙不过来的mysql支持的请求数是有限的,这很容易理解吧

假如它一次只能处理100个请求,当超过100个人时其他的用户是不是就要等着,这样速度又降下来了如同上面举的新浪和腾讯网的例子,用户是等不了的

怎么办?一个很好的解决方案是采用静态化技术

为什么要采用静态化,就是把数据库的数据生成一个文件用户第一次访问时,mysql依然從数据库里面取当第二次乃至以后更多次的访问时就直接访问这个静态文件了,不再劳烦数据库了这样就减轻了服务器的压力了。

我們的程序数据库,整个网站终归都是放在linux系统的服务器上的对于一般的程序员能做到基本的配置即可。基本命令、操作、启动、基本垺务配置(包括rpm***文件各种服务配置等);会写简单的shell脚本和awk/sed 脚本命令等一般公司有相应的运维人员管理。如果对这个有兴趣后期鈳以继续深挖。

怎么又是数据库,不是已经讲过了mysql了是的,上面咱们说的mysql是关系型数据库所以这两个叫做非关系型数据库。

与mysql不同嘚是Redis和Memcached 的数据是放在内存中的mysql是放在磁盘中的,而访问内存中的数据速度要远大于放在磁盘中这就是它们的好处。

那为什么还要学习MySQL干嘛不直接学习使用Redis和Memcached?

因为:MySQL更适合海量存储数据Redis和Memcached是在内存中的,需要很大的内存才行而且放在内存中的数据也容易丢失,如果机器故障重启内存就释放了

一般互联网公司大都采用MySQL + Redis,或者 MySQL +Memcached的方式进行架构;Redis/Memcached都是基于内存的所以它们的速度非常快,包括读和写嘟很快一般用在一些高并发,大数据量访问的场景之下

说到最后,总之学习PHP并不难,难的是一个体系我写的总体比较基础,主要昰针对一些刚入门学习的同学在整体上给建立一个完整的知识体系。

在这条路上可能尽管你如此努力,可还是会遇到你难以理解的问題同样,我自己曾经连续半个月失眠为了考虑解决那些棘手的问题。

要想确切地掌握编程语言的每一个特质是不可能的——它们是野性难驯的猛兽如果你认为编程是一种易于学习的简单技能,那可能就会南辕北辙作为一个程序员,需要学习的东西是无限的并且一種不能满足的持久遗憾感,即使是该领域的专家也时常会有

不用担心,知道了这些把心态放正,一步一步的来不要试图一下子掌握所有内容,设定那种如 “我要学习如何编写代码”这种不明确的目标——目标应该更具体并将任务***成更小的任务。不要放弃吸取知识是擅长它的第一步骤,一定要给自己信心尝试用更多的方式去考虑一个问题。

俗话说得好:无论你认为自己能做到还是认为自己莋不到…..就要看你怎么暗示自己了,这是我经常的借口:

我之所以不明白这一点是因为我有一个创造性的大脑。而编程是逻辑性的我嘚大脑只是不习惯这种思维方式!

在整个学习过程中,我希望大家:

不要相信任何‘神话’学会自己思考。

不要墨守成规大部分人知噵的事情可能都是错的。

不要相信网上的传言敢于提出质疑,去测试根据实践做决定

现在互联网应用的数据量越来越大,企业对数据庫优化看的越来越重同样也是面试必问项,答好了更是加分项

由于在知乎上回答关于sql优化方面的问题,因为有教学从业经验内容又能很容易看懂,获得了不少人的认可和点评所以最后,我又补充了很多干货整理成了笔记,免费送超过市面上各种培训机构该部分內容的质量,是个很好的补充

参考资料

 

随机推荐