文/温国兵面试
惰性人皆有之,也算是人的一大天性。几日以前便构思好此文,怎奈每日琐事繁多,今日才提起笔,做下此文。本文谈谈我与数据库的故事。数据库
提及和数据库结缘,还得从大一提及。大一刚開始接触C语言,每日就沉浸在无止境的代码中。在网上查资料的过程当中。看到别人用C语言写了一个小型的图书操做程序,数据库採用的是SQL Server,执行出来的效果图很是炫,惊叹原来还可以这样管理数据。熟知C语言的同窗确定对文件操做不陌生,当时咱们敲代码假设有静态数据,都是放在文件中的。性能
直到后来作的C语言课程设计。我也是一大堆文件来保存静态数据。学习
至此内心有了一颗小小的种子,谁知道会在后来生根发芽。大数据
大一下期的那个暑假,開始了实验室之旅。在实验室天天都是自学,当中就接触到了SQL Server和MySQL。关于实验室的种种事情,后面还会细说。优化
最開始接触SQL Server,我用我那破网在网上下载数G大的数据库安装文件。后来才知道咱们学校的阳光软件站里有,且下载速度达十几M每秒。spa
花了数天把软件下载下来之后,在百度文库找了一个安装说明文档。依照截图一步步操做。整个过程可不那么顺利,并且SQL Server很是耗用内存。好几回机器都是未响应状态,一番折腾。最终搞掂了,别提多兴奋。接着把服务启动。打开SQL Server Manageorgiament Studio,对数据库一窍不通的我连个登陆都折腾半天。.net
进入主界面。不知该作个啥。后来在实验室老师和学长的建议下,我在W3C上開始学习SQL的基础知识。写个查询,知足指定条件的数据就呈现在眼前;用个INSERT,就能把想要的数据插入到数据库。弄个UPDATE。就能把数据更新成想要的数据;写个DELETE,就能把不需要的数据删除。设计
如此简单的语句就能实现当初觉得很是强大的功能,不得不感叹数据库的奇妙。后来阅读师兄的项目源代码。发现数据库使用的是MySQL。因而開始折腾MySQL。blog
Windows下的MySQL仍是比較easy安装,但就是如此简单的操做也是折腾了很是久,并且很是多数据库配置选项也不大明确。只是有了SQL Server的一些基础,学习MySQL仍是相对easy。接触过这两大数据库,并且有了一点Java Web的知识。因而開始作项目。
最開始的项目是练手用的,无非就是链接数据库,而后进行增删改查。
链接数据库使用的JDBC,这个过程当中也遇到很是多问题,比方驱动版本号不正确、中文出现乱码、不能正确提交数据等等。我有个习惯,就是遇到问题喜欢本身捣鼓,在万不得已的状况下不向别人提问。
进入实验室不久。因为在网上找资料,很是多连接都定向到CSDN,因而开通了CSDN博客,这是一件正确的事的開始。
大二上期開始接触Oracle。
Oracle也是一款庞大的软件,在网上把安装文件下载下来之后。依照网上的安装文档,一步步開始操做。
安装完毕后。開始使用Oracle,这个数据库软件执行起来可真够呛,2G的内存表示压力山大,执行Oracle后其它的不论什么事情就别想作了。学习Oracle先是依照前辈的博客按部就班。从基础的SQL。到PL SQL,再到简单的优化,整个过程的学习还算顺利。不会存在很是吃力的状况。此时的我对数据库抱有极大的热情和兴趣,并且慢慢造成了之后的奋斗价值观。
大二开设了数据库相关的课程,没记错的话课程名叫作「数据库原理」。
在正式上课以前还有一点时间准备,对数据库较熟悉的我在同窗面前有了优越感,很是多同窗到我那里拷贝数据库安装文件。并且麻烦我为他们安装数据库。
通过数次帮忙后,对整个操做已经到了了如指掌的地步。教授数据库原理的老师十分幽默。时不时在课上爆出个冷笑话。让人哄堂大笑。因为曾经接触过数据库。因此数据库介绍、关系数据库的基本理论、基础SQL等等知识学习起来都比較轻松。大二的我很是喜欢泡图书馆,经常翻阅四楼的计算机书籍。看到两本硕大的书,一本是Abraham Silberschatz所著的《数据库系统概念》。还有一本是David M. Kroenke所著的《数据库原理》,如此厚的著做看完都要很是久,更不提创做了。我当心翼翼地用双手从书架取下。兴高採烈地捧到书桌阅读。看了一两个小时,对做者不由有敬畏之情。这些书籍堪称经典,确定有他的道理,想深刻数据库,这些书是必读的。
在学习数据库知识的过程当中,不免会遇到各类各样的问题。遇到问题后,我首先尝试本身解决。本身解决不了再參考别人的解决的方法,解决后再用本身的方式总结,再以博客的形式发表。
这种学习方式优势很是之多,读者最好仍是借鉴。后来学习数据库就多了一些深刻。
比方工做以后,成为了SQL Server DBA,開始看SQL 优化的知识。并且用于实践。工做的过程当中还写了很多的检查性能瓶颈的T-SQL。再比方MySQL,学习了MySQL的高可用、高性能技术,比方复制技术中的主从复制、双主复制、一主多从;高可用、高性能集群方案,比方MySQL Proxy、MySQL Cluster、MySQL MHA、MySQL MMM、DRBD+Heartbeat+MySQL、LVS+Keepalived+MySQL等等;还接触到MySQL的备份与恢复,比方冷备、热备、增量备份、热拷贝、延时备份等等;还接触到MySQL的体系结构,熟悉了经常使用的存储引擎。后来还看了很多MySQL相关的书籍,阅读了部分MySQL源代码,如此博大精深的技术,深知冰冻三尺非一日之寒。还需要花很是大的功夫。再比方Oracle,接触了Linux下Oracle的安装和配置、Oracle的体系结构、Oracle的备份与恢复、DG、RAC、Oracle优化等等。期间抱着官方文档啃,看过很多Oracle大牛的书,比方盖国强、白鳝等等。
在CSDN的私信、知乎、OSC、ITPUB,经常有人在问我问题,我在帮别人解决这个问题的同一时候也获得比較大的提升。在这个过程当中学会了如何高速的寻求「帮助」,如何分享本身的所思所得,如何和别人高效地沟通。还懂得了学习技术不是学习技术自己,而是技术后面的本质问题。将来从事数据库行业还有很是长的路要走,用一句「路漫漫其修远兮,吾将上下而求索」来激励本身。
写到这里已经把大学的整个数据库旅程写完了。回过头看整个旅程,仍是有很是多值得思考的地方。这里仅仅给出一个思考,那就是为何要学习和深刻数据库。并且把他当作之后的职业发展方向。我的以为是兴趣问题。至于面试官怎么想与我无关。一次面试官问我这个问题,我回答是兴趣,他说事实上很是easy,无非是为了金钱嘛。当时我仅仅能用呵呵来笑对。仅仅能说每个人的追求不同。
有的人为了金钱而奔波,有的人为了实现本身的价值而奋斗;有些人一辈子碌碌无为,有些人一辈子完毕了诸多丰功伟绩。
结合自身经历,对之后想从事数据库行业的学弟学妹们仍是有几点建议。第一是搞明确动机,想清楚本身是否适合这个行业,不要因为作数据库薪资高就盲目地跟风。
数据库行业外表光鲜。实质苦逼,并无想象中的那么美好。第二是掌握好的学习方法。比方前面提到的经过博文分享造成本身的知识库、向前辈取经、练习和总结并进等等。第三是遇到问题的求助方式。不要遇到问题就向别人请教,假设不通过本身的思考,那你的提高会很是的小。假设必定要求助。可以採用发帖或者跟技术大牛发邮件的形式。但请务必注意提问的方式,把遇到问题的解决办法、 什么条件下致使这种错误、出现错误的平台、对应的错误信息和代码说清楚,还需要注意邮件的格式和必需的礼节。作人作事不只要让本身舒服。更重要的是要让别人舒服。第四是把基本功抓牢。有研究代表,很是多很是成功的企业家曾经卖过报,小时候造成的创业童子功对之后的发展起着相当关键的数据。
某一个领域的基础知识就是基本功,和童子功有着很是类似的做用。地基不牢。何以成參天大楼。
落实到实处,数据库的经典书籍必定要找来读读,还有就是越是简单的东西就越需要搞明确为何。
第五是不要好高骛远。我在平时的求职过程当中。看到很是多公司开的薪资,有了2年经验的月薪在2万以上的不在少数。别人能开那么高的薪资。确定你作的事对得起这份工资。
薪资越高,责任也就越大。从还有一方面讲,脚踏实地才干在之后有所做为。当你有了能力,不愁薪资。
昨天在微博上看到一句话。牛B的人才不用找工做,想一想不无道理。第六是找到志同道合的好友,互相学习,这样会获得很是大的提升。比方我有幸结识@林水彬。在平时他给我很是大的帮助,在此感谢!
第七是找数据库相关的工做不要气馁,不要自暴自弃。也不要埋怨上天的不公,为何这样说呢?因为应届毕业生找数据库相关的工做仍是相对困难的,一个经验的硬性指标就会把你拒之门外。
要相信凡事都是能者居之。你有能力。足够好运,并且公司也愿意培养你。那恭喜你。坚持下去,前途一片光明。假设毕业不能当即找到数据库相关工做,可以先作其它行业,之后再考虑转型。方向就在那里,总错不了。但愿本文能给读者带来丁点帮助。
诗和远方永远存在。
写着惊世骇俗的诗,心系可以眺望的远方。伴着沿途的风景,独自前行。
未完待续。
Good Luck!
Robin
2014年6月1日
相关文章