高效MySQL数据库的正确编写
创始人
2024-07-01 01:21:39
0

以下的文章主要介绍的是编写高效的MySQL数据库的正确方案,我们首先是借助Apach、Perl与PHP以及Python等实际应用工具,来构建一个关于MySQL(和PHP搭配之最佳组合),其应用时很容易的。

然而确保它们运行快速,则需要一点洞察力。本文就是你需要知道的东西。

MySQL(和PHP搭配之最佳组合)对于成为一个非常快速的MySQL数据库服务器有着当之无愧的名声,它也非常容易设置和使用。随着它作为网站后端数据库得声望日增,其效果在去年开始有明显提高。但是很多MySQL(和PHP搭配之最佳组合)用户更多地知道如何创建一个数据库并编写对它的查询。就像成千上万的人通过载闲暇时用Linux做实验来学习Unix那样,很多人通过玩MySQL(和PHP搭配之最佳组合)学习关系数据库。这些MySQL(和PHP搭配之最佳组合)新手的大多数既没有关系MySQL数据库理论的背景,又没有时间阅读MySQL(和PHP搭配之最佳组合)手册全文。

因此,我们决定研究某些方法,你可以用针对优化性能来调节MySQL(和PHP搭配之最佳组合)。在读完本文后,你将理解一些帮助你设计你的MySQL(和PHP搭配之最佳组合)数据库和查询的技术,值得你的应用很有效率。我们将假定你熟悉MySQL(和PHP搭配之最佳组合)和SQL基础,但不假定你有这两方面的广博知识。

只存储你需要的信息

这听上去是常识,但人们常常采取“厨房下水道”的方式进行数据库设计。他们认为可能项要得每样东西都要存储并设计数据库保存所有者这些数据。你需要对你的需求现实些,并确定取确实需要什么信息。你常常能随意产生一些数据而不把它存在MySQL数据库表中。在这种情况下,从一个应用开发者的角度看也有道理这样做。

例如,在线目录的产品表可能包含各种产品的名称、介绍、尺寸、重量和价格。除了价格,你可能想存储每个项目相关的税和运输成本。但实际上不必这样做。首先税和运输成本可以方便地(由你的应用或MySQL(和PHP搭配之最佳组合))计算出来。其次,如果税和运输成本改变了,你可能必须编写必要的查询更新每个产品记录中的税和运输的费率。

有时人们认为这太难不能在以后往MySQL数据库表中加入字段,所以他们感觉不得不定义尽可能多的列。这是明显的概念错误。在MySQL(和PHP搭配之最佳组合)中,你可以用ALTER TABLE命令方便地修改表定义以适应你改变的需求。

例如,如果你突然认识到你需要给你的产品表增加一个级别列(可能你想允许用户在你的目录中给产品评级),你可以这样做:

 

  1. ALTER TABLE products ADD rank INTEGER 

这给你的产品表增加了一个整数类型的级别列,你能用ALTER TABLE做什么的完整介绍参见MySQL(和PHP搭配之最佳组合)手册。

只要求你需要的东西--要清晰

就像说“只存储你需要的东西”那样,这可能看来是常识,但这一点常常被忽视,为什么呢?因为在一个应用开发时,需求经常改变,所以很多查询最终看来是这样:

  1. SELECT * FROM sometable 

当你不能肯定你将需要哪一列时,要求所有列明显是最省力的事情,然而随着你的表不断增大和修改,这可能变成一个性能问题。最好是在你的最初开发完成后再花些时间并确定你真正从你的查询中需要什么:

  1. SELECT name, rank, description FROM products 

这带来了一个相关的观点,即代码维护比性能更重要。大多数变成语言(Perl、Python、PHP、Java等)允许通过字段名和数字编号访问一条查询的结果,这意味着你可以访问命名字段或字段0都可以得到相同的数据。

长期看,最好使用列名而不是其编号位置,为什么?因为一个表中或一条查询中地列的相对位置可以改变。它们在表中可能因为重复使用ALTER TABLE而改变,它们在查询中将因重写了查询而忘记更新应用逻辑来匹配而改变。

当然,你仍然需要小心改变列名!但如果你使用列名而非标号位置,如列名改变,你可以用grep搜索源代码或使用编辑器的搜索能力查找你需要修改的代码。

以上的相关内容就是对教你如何编写高效的MySQL数据库应用的介绍,望你能有所收获。

【编辑推荐】

  1. 对开源MySQL数据库的介绍
  2. 对MySQL镜像数据库进行建立在linux下
  3. MySQL索引被破坏所产生的问题解决
  4. MySQL5字符集问题的解决方案
  5. MySQL启动方法与实际操作步骤

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
P2P的自白|我不生产内容,我... 现在一提起P2P,人们就会联想到正在被有关部门“围剿”的互联网理财服务。×租宝事件使得劳...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...