设计MySQL数据库的技巧

来源:asp之家 时间:2009-09-06 11:56:00 

就MySQL而言,大多数程序员都不太了解其设计背景,因此当他们尝试创建自己的数据库时,会留下很多漏洞。

要想为MySQL数据库进行合适的配置,你的网络应用应该是有效且可靠的,因为它符合行业内设置数据库的标准。

如何MySQL数据库设计得很合理,我们会得到下面几个好处:

·速度——由于数据库效率很高且使用正确的数据类型和字符长度,那么查询速度就会得到相应改善。

·安全性——我们可以让特有数据保存在MySQL数据库中,所以安全性得到了改善。

·存储空间效率——由于你开发的数据库是完全基于数据说明的,那么在MySQL数据库中就不存在多余的字节和字符。这样就可以节省磁盘空间。

这篇文章将着重介绍如何为PHP网络应用设计一个MySQL数据库以及如何使用phpMyAdmin界面。下面是我们对程序员提出的几点要求:

·XAMPP,用于测试PHP脚本和访问phpMyAdmin。

  ·一系列域以及数据类型。要对需处理和保存的数据有比较完整的了解。

  ·要需要保存的数据中的字符数量。

请注意,本教程已经过MySQL 5.0.67的测试。不同的MySQL版本可能会影响数据库的设计,但是基本的原理还是相同的。本教程假定所使用的表格格式是MyISAM,它也是MySQL的默认表格。

为数据库,表格,域名和数据类型命名

为了帮助你了解整个过程,我们要结合实际操作来讲解。假设你需要设计一个接收客户投诉的网络应用。你可能会想到下面这些数据。每次出现与客户相关的投诉时,就需要从网络表单中收集这些数据。

·客户名

·价格。在小数点前不要超过4位数,小数点后仅保留3位数。同样保存的数值不能为负数。

·购买日期。(使用yyyy-mm-dd)

·产品序列号(仅限整数,不能为负,五位数,如果小于五位则用零代替)例如:00567,56453,00021。

·投诉细则(可接受任意长度的文本信息)。

·接收投诉的日期(显示表单提交时的时间和日期)

现在我们已经定义了需要收集的数据,下一步是为数据库和表格指定名称。

依据MySQL指导,我们知道数据库名称,表格名称和域名都不能超过64个字符的长度,而且其中还不能包含特殊字符。

我们可以将数据库命名为 “customercomplaint”,然后将数据库表格命名为“customertable”。名称越简单,在相关PHP脚本中就越容易使用。避免使用较难的或是较复杂的数据库名称,表格名称和域名,因为当你为数据库制定PHP查询时,复杂的名称会带来一些困惑 

至于这些变量的对应的数据类型,下面的截图给出了一些可用的MySQL数据类型。

最常用的MySQL数据类型是VARCHAR, DECIMAL, DATE, INT, TEXTTIMESTAMP

VARCHAR通常用来表示最多为255个字符的变量长度字符串。如果你要储存和处理字母数字类的数据,这种数据类型是最合适的。适用于这类数据的典型例子包括人名,邮政编码,电话号码和不超过255个字符长度的任意字母数字组合。那些要用来计算的数字不要用VARCHAR类型保存,因为可能会导致一些与计算相关的问题。换句话说,可能影响到计算的准确性和完整性。

DECIMAL最适合保存那些将被用于计算的数据。在MySQL中,我们可以指定保存一些正当的数字。还可以指定是否允许存在负值。

指定DECIMAL类型的长度会有些棘手。例如,如果你需要在小数点前面保存五位数,且小数点后只保留三位,那么在数据库中其适当的长度将是:Decimal(5+3,3)或 Decimal(8,3),可以使用的数据包括:12345.678,56872.690,11.6和12.568等。而这些数字则会引发出错信息:128781.1,8972865.231。

建议用DATE数据类型来保存日期。MySQL中默认的日期格式是yyyy-mm-dd。

INT数据类型可以用来保存那些不包含小数点的数字。INT代表整数。

有些整数类型以及他们最多所能拥有的数字位我们必须有所了解:

·TINYINT——这个类型最多可容纳三位数。

·SMALLINT——最多可容纳五位数。

·MEDIUMINT——最多可容纳八位数。

·INT——可以容纳十位数。

·BIGINT——最多可容纳二十位数。

TEXT可以接受文本输入,VARCHAR只能接受255个字符,但是TEXT可以用来存储超量的数据。

当TIMESTAMP数据类型被选定,可以点击“CURRENT_TIMESTAMP”作为默认,MySQL会自动返回每个MySQL数据插入的确切时间。

标签:mysql,数据库,phpMyAdmin
0
投稿

猜你喜欢

  • 运行SQL Server的计算机间移动数据库

    2009-01-20 13:07:00
  • 仿china.nba.com焦点图轮播展示效果(ie6,ff)

    2008-04-21 12:54:00
  • 分享一个Emeditor压缩样式的宏

    2010-08-16 12:30:00
  • MSSQL2005数据附加失败报错3456解决办法

    2012-11-30 19:56:59
  • 详解SQL Server中数据库快照工作原理

    2009-01-21 14:18:00
  • 创建IE各版本专属CSS方法

    2007-09-27 12:16:00
  • 利用ASP发送和接收XML数据的处理方法

    2009-02-02 08:57:00
  • 加快Firefox 3.5启动速度的方法

    2009-07-16 15:22:00
  • asp函数转换xml中的实体字符[转义符]

    2008-10-16 17:07:00
  • 编写SQL Server的扩展存储过程实例

    2009-01-20 15:45:00
  • PHP对战ASP:这还值得讨论吗

    2008-04-16 14:19:00
  • 段正淳的css笔记(4)css代码的简写

    2007-11-01 22:03:00
  • 巧妙规划使用Oracle数据空间

    2009-03-20 11:51:00
  • W3C web标准概念入门

    2008-05-25 15:06:00
  • 用ASP建立一个简单的聊天室

    2007-09-21 12:43:00
  • ASP程序与SQL存储过程结合使用详解

    2011-03-25 10:50:00
  • 3个常用的JS时间代码

    2009-03-22 15:29:00
  • ASP截取中英文字符串固定长度

    2009-08-19 17:12:00
  • CSS文件的编码要和页面的编码相一致

    2010-06-06 13:59:00
  • 浅谈图表参数化设计

    2010-08-29 18:03:00
  • asp之家 网络编程 m.aspxhome.com