SQL Server 移植到Oralce 项目实战
项目背景
移植一个现有系统到Oracle。原系统基于.Net Framework 1.1, SQL Server 2000数据库,数据操作基本全部使用Store Procedure,总数逾千,因此总体涉及的PL SQL 开发量比较大。
优先级高,开发时程短,参与人员多,是这个项目的显著特点。本人作为项目负责人,主要按照下列步骤进行,最终圆满达成目标。
第一步 评估
1. 确认需要移植的功能列表
2. 评估主要工作量
工作重点在于移植SQL Server SP到 Oracle Package,预估移植一个SP所需平均时间等
第二步 前期准备
1. 确定目标Oracle数据库的版本(Oracle10.1.0.5.0)和编码(ACTUTF8)
数据库的编码确定非常重要,由于原系统支持多语言存储,所以Oracle我们选择了ACTUTF8。这种编码对应的SQL Server 中,1个字符占3个字节。
2. Oracle 数据库设计(咨询Oracle DBA)
3. 评估技术难点,找解决方案
1) Identity栏位实现
使用Trigger
2) 临时表实现
使用Oracle的临时表(8i后已提供)
3) .Net Oracle驱动程序
采用ODP.NET
4. 确定SQL Server -> Oracle 表 / 栏位映射关系,形成SQL Server/Oracle 表对照文档
1) 一般原则,原对象的名称不做改变;
2) 栏位类型,字符类型 -> VARCHAR2, 数字类型 -> NUMBER(m, n);
3) 栏位长度,最大长度 *3, 保存固定长度ID的栏位长度不做变更;
4) 在Oracle 中建立对应表,通过SQL Server DTS导入基础数据
5. SP使用Package组织,并重新命名,形成SQL Server/Oracle SP对照文档。
因为Oracle 对象名称长度不能超过30,SQL Server 的SP长度普遍超过30,因此需要重新命名并分组。
6. &nb
相关文档:
今天星期天,因数据库太慢,最后决定将数据库进行重新整理.
(假定数据库名称为:DB_ste)
1、根据现在的数据库的脚本创建一个脚本文件(FILENAME:DB_ste.sql)
2、建立新的数据库DB_ste2,若有文件组的数据库,则需要建立相同的文件组。(DB_ste_Group)
3、将数据文 ......
前段时间 把之前的无限分级表稍微做了一些改进 改进后的表结构如下
ID Name ParentID ParentIDList level
1 A 0 0-1 &nbs ......
<?php
require_once '../../smartyConfig/smartyConfig.class.php';
require_once '../../game/include/function.php';
require_once '../../game/include/config.php';
require_once '../../game/server/server.class.php';
require_once '../../game/include/db.class.php'; ......
作者 Haidong Ji 翻译 GoodKid
我们当中的大部分人工作在一个单一的 RDBMS 系统中,如 MSSQL, Oracle, or IBM DB2。然而,我们日益感觉到,我们正处于不同的数据库环境当中并且需要解决数据的互用性问题。
尽管主要的 RDBMS 厂商试图去遵循关系数据库模型原理,并且用非常小的差异去实现它们。另外,几乎主要的 ......
大家好!最近又有了一些模块用法的心得,那就是利用模块使你的内存变成一个虚拟的数据库模式,使你可以在没有数据库的情况下,将txt文件的数据进行 sql语句处理,感觉很新鲜吧,不过这个不用感到惊讶,Perl一直是很完美的,哈哈,那我们就来看看这个神奇吧!
需要安装 模块:
SQl::Library;
DBI
下面是程序 ......