ホームページ >バックエンド開発 >PHPチュートリアル >DB2 および PHP に基づくアプリケーション システムのクロスプラットフォーム移行の詳細な手順 (1)_PHP チュートリアル
本文主要介绍如何完成基于 DB2 的 PHP 应用系统从 AIX 平台到 Linux 平台的移植过程。文中包含了底层的 DB2 数据库移植、上层的 PHP 应用系统移植的详细步骤以及移植过程中可能遇到的问题和解决方法。 任务概述 系统迁移的工作主要分为以下几个方面: 1.DB2 数据库系统的跨平台迁移 2.Apache 服务器与 php 应用系统的安装和配置 下面我们就分 2 个方面分别介绍迁移和配置的具体步骤。 DB2 数据库系统的跨平台迁移 数据库环境 源环境:AIX+DB2 v8.1 目标环境:Linux+DB2 v8.1 其中源数据库中包含了 2 个数据库 Instance:SRCDB1 与 SRCDB2。在 SRCDB1/SRCDB2 数据库中,均包含了上百张数据库表,并有很多的索引、外键约束、触发器、存储过程以及一些含有自增字段的表(含有 GENERATED ALWAYS AS IDENTITY 定义字段的表)。更为困难的是,我们并没有关于这些数据库对象的准确创建脚本。 迁移方案的选择 如果迁移的源系统与目的系统属于同一类型操作系统,例如 Linux 之间的迁移,或者 AIX 系统之间的迁移,则情况相对简单,DB2 本身已经提供相关的实用工具来实现这种同类型平台之间的数据库移植,如: BACKUP 和 RESTORE 命令。当然,根据不同的情况还需要对实用工具所提供的参数有比较清楚的了解,譬如源系统与目标系统使用不同的表空间,就会涉及到表空间重定向的问题。由于本文的重点在于跨平台的移植,这种方案显然无法满足需求,在此不再熬述。 那么,如何处理跨平台的数据库迁移问题?是不是可以使用实用工具 db2move 呢? db2move 只能迁移表中的数据,而无法对索引、外键约束、触发器和存储过程等数据库对象也实现迁移操作,而且对于包含自增字段数据的表来说,db2move 也有一定的限制。并且 db2move 只能把数据导入到已存在的数据库的表中,无法显示指定表空间的位置。由于在数据库的系统迁移过程中,不仅需要迁移表中的数据,还有索引、外键约束、触发器和存储过程等数据库对象,与本文所选方案相比,还是后者更具优势。可以将 db2move 仅作为迁移表数据的一种备用方案。 而对于 export 和 import 来说,一次只能针对一张表进行导出导入操作,并且需要手动输入 export 和 import 的命令以及需要导入导出的数据表名,在数据库表的数量不多的情况下,这种方案也许还可以考虑,但也不并是最佳的方案。而在数据库中表数量众多的情况下,这种做法则是基本不现实的,而且 import 命令并不能保证自增字段的数据与原来的表数据保持一致。 本文根据 DB2 对数据库对象的处理机制,采用将 db2look 与 DDL、DML 脚本相结合的方式,并针对原数据库中的触发器、存储过程以及外键约束等分别处理,给出了一种跨平台 DB2 数据库系统移植的可行方案。 下面我们以 SRCDB1 为例介绍一下这种情况下的数据库整体迁移过程。SRCDB1 数据库中有 SRCDB1、ASN、DB2DBG 和 SQLDBA 这四个数据库模式。假设 SRCDB1 数据库的用户名为 user_srcdb1,密码:pw_srcdb1。 在源系统 (AIX) 上的相关操作 1.使用 db2look 命令抽取生成数据库对象的 DDL 脚本 清单 1. db2look 命令及参数 # db2look -d SRCDB1 -e -o srcdb1.ddl -a -i user_srcdb1 -w pw_srcdb1 db2look :生成 DDL 以便重新创建在数据库中定义的对象 语法: db2look -d DBname [-e] [-u Creator] [-z Schema] [-t Tname1 Tname2...TnameN] [-tw Tname] [-h] [-o Fname] [-a] [-m] [-c] [-r] [-l] [-x] [-xd] [-f] [-fd] [-td x] [-noview] [-i userID] [-w password] [-v Vname1 Vname2 ... VnameN] [-wrapper WrapperName] [-server ServerName] [-nofed] -d : 数据库名称,必选参数 -e : 抽取复制数据库所需要的 DDL 文件,此选项将生成包含 DDL 语句的脚本 -o : 将输出重定向到给定的文件名,如果未指定 -o 选项,则输出默认转到 stdout -a : 为所有创建程序生成统计信息,如果指定了此选项,则将忽略 -u 选项 -i : 指定登录到数据库所在服务器时所使用的用户标识 -w : 指定登录到数据库所在服务器时所使用的密码 2.根据不同类型对象,分化数据库对象 DDL 脚本 ソースデータベースの各テーブルデータはトリガーやストアドプロシージャなどのデータベースオブジェクトによって処理されているため、データベース内のデータの一貫性と整合性を確保するには、データのインポート後にこれらのデータベースオブジェクトを作成して、繰り返しを防ぐ必要があります。テーブル データをインポートするときに、トリガーやストアド プロシージャなどのデータベース オブジェクトを実行すると、不正なデータが生成されます。テキスト エディターを使用して、db2look によって生成された srcdb1.ddl を編集し、テーブルとインデックスの作成、外部キー制約の作成、トリガーとストアド プロシージャの作成を行う DDL ステートメントを 4 つのグループに分割し、次の 4 つの DDL スクリプトとして保存します。
srcdb1_tables.ddl srcdb1_foriegnkeys.ddl
各行モード DB2SQL WHEN ( n.col1 > 3) で NEW AS n を参照
現在のスキーマを設定 = " SRCDB1";
db2 カタログ データベース SRCDB1 を SRCDB1 として;