Heim  >  Artikel  >  Datenbank  >  MySQL数据库移植中会产生什么问题?

MySQL数据库移植中会产生什么问题?

WBOY
WBOYOriginal
2016-06-07 16:11:271028Durchsuche

以下的文章主要介绍的是把Oracle数据库移植到MySQL数据库我们应注意的相关事项的描述,我们大家度知道Oracle数据库以是现在应用最为广泛的数据库,而MySQL数据库的应用率是远不如Oracle数据库。 客户用的数据库是MySQL数据库(和PHP搭配之最佳组合),而研发好

以下的文章主要介绍的是把Oracle数据库移植到MySQL数据库我们应注意的相关事项的描述,我们大家度知道Oracle数据库以是现在应用最为广泛的数据库,而MySQL数据库的应用率是远不如Oracle数据库。

客户用的数据库是MySQL数据库(和PHP搭配之最佳组合),而研发好的产品支持Oracle(大型网站数据库平台),为了让客户掏腰包,我们必须把数据库环境从Oracle(大型网站数据库平台)转向MySQL(和PHP搭配之最佳组合)。我们在转换的过程中碰到了下面一些问题,希望能给同样遭遇的同仁们一些借鉴。

如果我们在最初的设计、编码过程中注意数据库的移植性,这种情况下可以完全不需要作额外工作。

一、数据库环境从Oracle(大型网站数据库平台)转向MySQL(和PHP搭配之最佳组合)碰到的问题。

因为逻辑不变,所以原则是不改应用程序代码,只改数据库表的创建/初始化sql。下面是我们碰到的问题以及解决办法。

1、 大小写敏感的区别(如果服务器OS是linux)。

在Oracle(大型网站数据库平台)中一般情况下不区分大小写。有时候我们在使用Oracle(大型网站数据库平台)不注意大小写的问题,表名和字段名不加双引号是不区分大小写的,像这样:insert into tableName 和 insert into TABLENAME效果是一样的,用工具导出创建/数据初始化脚本,得到的结果一般表名和字段名转化成了大写。

但在MySQL数据库(和PHP搭配之最佳组合)中,所使用操作系统的大小写敏感性决定了数据库名和表名的大小写敏感性。数据库对应数据目录中的目录,数据库中的每个表至少对应数据库目录中的一个文件(也可能是多个,取决于存储引擎)。

因此,使用数据库或表实际上是操纵这些文件(夹),所以使用操作系统的大小写敏感性决定了数据库名和表名的大小写敏感性。在以linux为内核的操作系统中是大小写敏感的。

解决的办法是把MySQL(和PHP搭配之最佳组合)的数据库名和Oracle(大型网站数据库平台)的大小写保持一致,表名与应用程序中sql字符串中的表名保持一致,如果应用程序中字段名用了双引号,那请把sql中的字段名大小写与双引号里的字符保持一致。如果你的应用程序所引用的表名、字段没有统一大小写,那麻烦就大了。

2、保留字的区别。

像sql语言的函数名(如:inteval,show)等是保留字。Oracle(大型网站数据库平台)中保留字是可以作为表名和字段名,并且不影响使用,但MySQL(和PHP搭配之最佳组合)中保留字是不能作为表名和字段名,如果使用会报语法错误。

解决办法,把sql语句中的保留字用‘`’符号引起来,这个符号位于键盘的tab键上面;如果是字段名还有另外一种方法tablename.字段名。像这样:insert into tablename (id, `interval`) value(….. 或insert into tablename (id, tablename.inteval) value(….. 。

3、数据类型的区别。

在MySQL(和PHP搭配之最佳组合)中没有像Oracle(大型网站数据库平台)中的varchar2、number,MySQL数据库(和PHP搭配之最佳组合)有与之对应的varchar、numeric,当然在Oracle(大型网站数据库平台)中没有MySQL(和PHP搭配之最佳组合)的time类型。

解决办法是替换。

4、自动增长类型的区别。

Oracle(大型网站数据库平台)有sequence,MySQL(和PHP搭配之最佳组合)中没有,但有auto_increment属性。

解决办法是把Oracle(大型网站数据库平台)中sequence转换成使用auto_increment属性,某些情况可能还有一种办法可以解决问题,新建一个独立的表用来专门记录自动增长型的数据。

5、索引长度限制的区别。

从MySQL(和PHP搭配之最佳组合) 4.1.2开始,MyISAM和InnoDB表索引长度支持1000字节,也就是说索引字段的长度不能超过1000字节,如果超过会报这样的错:ERROR 1071 (42000): Specified key was too long; max key length is 1000 bytes。如果是UTF-8编码,相当于333个字符的长度(因为UTF8一个字符占3个字节)。Oracle(大型网站数据库平台)的索引长度限制比MySQL数据库(和PHP搭配之最佳组合)要宽松得多。

解决的办法就不必要多说了,要么改索引的定义,要么改字段的定义长度。

二、为了数据库的兼容性我们应该注意些什么。

数据库的兼容性应该是数据库设计应该重视的一个问题,因为有时候客户存在已经在用的数据库,并且不希望同时维护两个数据库,这样的话兼容多种数据库还能成为产品的一个卖点。

作到数据库的兼容性关键是遵守标准用法。

1、 遵守标准用法,尽量不使用某种数据库特有的用法。

如msyql的‘`’符号的用法,

再比如,很多人有这种用法,在使用Oracle(大型网站数据库平台)开发的时候创建sequence,往表中插数据之前先SELECT seq.nextval FROM DUAL;,然后把查询得到的值作为value插入表中,这种用法没法适应没有sequence的数据库,每个数据库都有自动增长型的用法,如果需要使用就应该完全地使用。

再举个例子,不同的数据库对分页查询作了扩展,postgresql有offset,limit,Oracle(大型网站数据库平台)就没有。

2、 避免数据库大小写敏感的问题。

选择数据库表名和字段名采用大写还是小写,并且在数据库的设计和编码过程中完全统一。

3、 保留字。

要求数据库设计者尽量不使用保留字作表名和字段名。也有很多人有这种用法,在表名和字段名前加‘_’,像这样:create table _tablename ( _id integer)。这样永远不会出现保留字引起的问题。


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn