现在市场上存在很多厂商推出的数据库管理系统,商业化的有Oracle、MSSQLServer、DB2、SybaseSQLServer、Informix,开源的有MYSQL、SQLite、SimpleSQL、Berkely DB、Minosse、Firebird、HSQLDB等,这些数据库产品的出现给了开发者更多的选择余地,比如:系统对安全性、稳定性以及售后技术支持要求非常高,那么就可以选择Oracle或者DB2;如果系统只运行在Windows操作系统下那么可以选择MSSQLServer;如果不想为数据库管理系统承担费用,那么可以选择免费版的MYSQL;如果对数据库的要求不高只是提供一个方便数据存取机制,那么可以使用HSQLDB等嵌入式数据库系统。不过,这在给我们带来选择便利的同时也给开发者带来了麻烦,比如:开发的系统是以产品的形式发售的,要求能够运行在所有主流的数据库管理系统下;为了降低成本,在开发阶段使用免费版的MYSQL进行开发,然后在部署阶段要运行在Oracle 下;旧有系统运行在Informix 下,现在要求平滑迁移到DB2 下。
众所周知,各个数据库管理系统支持的SQL语法是存在一定差异的,在Oracle下能够成功运行的SQL迁移到DB2下可能就无法运行,因此如何使得系统能够在多种数据库管理系统下运行就成了一个非常棘手的问题,本章将首先对主流数据库管理系统的SQL语法差异进行介绍,然后提出相应的解决方案。