将您的网站从MySQL改为Postgre SQL

2008-02-23 07:39:04来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

我的站点最初是采用PHP驱动,由MySQL数据库支持的方案,这在当时是个明智的方案。在2001年夏天,我将我的数据库换成了PostgreSQL(有时也简称为Postgres)。

这个教程分为两部分,第一部分讲述了我进行这种转换的动机,并一步步地解释了如何将已存在有MySQL的数据转换到Postgres中。第二部分将会解释如何根据新的数据库系统对PHP进行相应的调整。

转换的动机

我第一次了解Postgres是在PHPBuilder网站的一篇文章中。这篇文章将Postgres和MySQL进行了比较,当时我正在使用 MySQL。但是,当我阅读了这篇文章后,我对Postgres着了迷 -- 但是当时我还没有想到对我的网站进行重新的设计。

我继续使用MySQL,因为我的主机提供商只能提供MySQL的支持,这是我所无法改变的。直到有一天,主机提供商的主机崩溃了。我立即换了一个主机提供商,和原来的那个相比,新的主机提供商有很多不同,他们在安全性和稳定性方面对我作出了更多的承诺。新公司试图说服我使用Postgres,因为 Postgres要比MySQL来得更稳定,但是我当时没有接受这个建议,因为我的网站已根据MySQL完成了全部的编码工作。他们只好专门为我的站点安装了MySQL。于是问题开始了。

我的第一个工作是将旧服务器上的MySQL的数据拷贝到新的主机上。首先,我将已有的数据dump到一个SQL文档中,然后在新的主机上导入这个SQL文档。在处理这个数千行的文档时,MySQL迅速地崩溃了。重启MySQL后,其中大概只有一半数据成功地导入了,而且MySQL只能间歇性地工作。最后,他们不得不删除了已导入的信息让我再试一次。MySQL再次崩溃。这种情况重复了好几次,直到最终我决定将我的SQL文档分割成几块。我不得不又试了几次,最后终于将绝大多数的数据都成功地导入到新的MySQL服务器中。一切都好了,我总算松了一口气。

在下面的几个月中,MySQL几乎每两周都要崩溃一次,其中最惨痛的一次是在2001年6月底。这一次,存储在MySQL中的数据完全被毁坏了。我有一个 SQL的备份文档,但是因为上次向MySQL中导入大量数据的痛苦的经历,这一次我再也不想通过这个备份恢复数据了。这时,公司再次建议我对我的网站进行转向,使用Postgres。由于MySQL的失败,最终我接受了这个建议。

将数据从MySQL转移到Postgres中

将数据从MySQL转移到Postgres是个不大的挑战,因为Postgres比MySQL支持了更多的SQL的标准格式,在POstgres中直接使用SQL的dump结果是不可能的。但是,SQL语法相当相似,因此对于我来说,这并没有花费太多的时间。

对MySQL的Dump结果进行转换

首先,需要您的主机提供商为您的帐号建立一个数据库。和MySQL数据库相同,Postgres的数据库也由一系列包含实际数据的数据表组成。然后,使用mysqldump命令为您的MySQL数据库做一个dump文档。

mysqldump -u username -p databasename > sqldump.txt

使用FTP将整个dump文档下载下来。现在在您的电脑上有了这个SQL文档,您能够将其转换成Postgres能够导入的文档。

首先,从dump文档中剪切任何的MySQL的CREATE TABLE查询,并将其粘贴到一个单独的文本文档中。下一步是使用Postgres能够理解的语言重新对数据表进行定义。

Postgres建立表的SQL和MySQL很类似,但不完全相同。下面是个例子:


在一个Postgres的表定义中,字段名后面必须跟着字段类型。在上面的例子中我们给出了一些最普通的字段类型,您还能够在有关Postgres数据类型的文档中找到全部的字段类型的列表。对于不同的任务,Postgres在字段类型方面有多种选择,并能够存储各种类型的数据,从Internet地址到货币信息到几何对象的定义。这儿简要地介绍最常用的几种数据类型。

SERIAL类型的字段和MySQL中的自增唯一ID等价。当您在您的数据表中定义了一个SERIAL类型的列后,SERIAL的自增功能会被自动添加到数据库。当自增功能不能适应实际需求时,我们能够自定义唯一ID的逻辑。从MySQL向Postgres转输数据时,默认的功能已足够了。

和字面上的意义相同VARCHAR类型是个可变长度的文本字段。字段的长度由括号中的数值定义。例如,VARCHAR(5)定义了一个最多可包含5个字符的文本字段。

SMALLINT、INT和BIGINT用来定义整型字段。SMALLINT字段可存储数值范围为-32768到 32767(实际的范围可能会稍微受到您的电脑类型的影响,上面的范围适用于最普通的系统)。INT字段可存储数值范围为-2147483648到 2147483647。而BIGIN字段类型可存储任何更大的整数,他没有范围的限制。

REAL字符类型是个包含十进制小数的实数。他能够精确到小数点后六位。DOUBLE PRECISION字段和此相类似,但是他能够精确到小数点后15位。

BOOLEAN字段是真或假、1或0。这和MySQL中相似。

TIMESTAMP字段和MySQL中的情况类型。每次记录更新时,timestamp被更新为当前的日期和时间。Postgres的时间字段还能够包含时区信息。有关Postgres时间数据的更复杂的应用,请参看PostgreSQL文档的日期和时间。

建立数据表

当您使用SQL文档在Postgres中建立数据表时,请检查在每一个CREATE TABLE查询的最后是不是都以分号结束 - 这对于Postgres是不可省略的。使用telnet这样的工具连接到您的Web主机,然后用下面的方法建立数据表。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: 精讲MySQL数据库的SQL语法参考

下一篇: MySQL代码如何在 Windows环境下编译