SystemDataOracleClient 和 SystemDataOleDb 命名空间
虽然通过这两个命名空间的类都可以访问 Oracle 数据库但和 SQL Server 类似的(SystemDataSqlClient 命名空间的类效率要比 SystemDataOleDb 命名空间中的类高一些)SystemDataOracleClient 命名空间中的类要比 SystemDataOleDb 命名空间的类效率高一些(这一点我没有亲自验证但大多数地方都会这么说而且既然专门为 Oracle 作的东西理论上也应该专门作过针对性的优化)
当然还有另一点就是从针对性上说SystemDataOracleClient 要更好一些
比如数据类型SystemDataOleDbOleDbType 枚举中所列的就没有 SystemDataOracleClientOracleType 枚举中的那些有针对性另外Oracle 的 Number 类型如果数字巨大超出 NET 数据类型范围的情况中就必须使用 SystemDataOracleClient 中的专门类 OracleNumber 类型
好了不再赘述这两个的比较下面主要讨论 SystemDataOracleClient 命名空间中的类型即 ADONET for Oracle Data Provider (数据提供程序)
数据库连接
无论是 SystemDataOleDb 还是 SystemDataOracleClient 访问 Oracle 都需要在 NET 运行的机器(ASPNET 中就是 Web 服务器)安装 Oracle 客户端组件(这一点是和 MS 的两种数据库不同的MS 的东西安装 MDAC: Microsoft Data Access Component 以上版本后就无须再安装 SQL Server 客户端或者 Office 软件就能访问)
System Requirements
()如用 SystemDataOracleClient 访问 Oracle客户端组件版本应在 Oracle i Client Release ()以上版本MS 只确保访问 Oracle Oracle Oracle i 服务器时的情况MDAC 以上
()如用 SystemDataOleDb 访问 Oracle客户端组件版本 以上或 以上MDAC 以上
如服务器为 Oraclei 以上客户端组件版本应为 c
在 NET 运行的机器中安装 Oracle 客户端然后打开 Net Manager (Oracle i) / Easy Config (Oracle i) 按你以前的经验设置本地服务的映射(这里的服务名将用于数据库连接串)
SystemDataOracleClient 中访问 Oracle 数据库的连接串是
User ID=用户名; Password=密码; Data Source=服务名
(上述为一般的连接串详细的连接串项目可以在 SystemDataOracleClientOracleConnectionConnectionString 属性的文档中找到)
SystemDataOleDb 中的访问 Oracle 数据库的连接串是
Provider=MSDAORA; User ID=用户名; Password=密码; Data Source=服务名
Oracle 中的数据类型
Oracle 的数据类型和 SQL Server 相比要奇怪一些SQL Server 的大多数据类型很容易找到 NET 中比较接近的类型Oracle 中的类型就离 NET 类型远了许多毕竟 Oracle 是和 Java 亲近的数据库
number: 数字类型一般是 Number(MN)M是有效数字N是小数点后的位数(默认)这个是按十进制说的
nvarchar: 可变长字符型(Unicode)这个比较像 SQL Server 的 nvarchar(但不知 Oracle 为什么加了个)(去掉n为非 Unicode 的下同)
nchar: 定长字符型(Unicode)
nclob: 写作文的字段存储大量字符(Unicode)时用
date: 日期类型比较接近 SQL Server 的 datetime
Oracle 中字段不能是 bit 或者 bool 之类的类型一般是 number() 代替的
和 SQL Server 一样在 SQL 命令中字符类型需要用单引号()隔开两个单引号()是单引号的字符转义(比如 Im fat 写入一个 SQL 命令是 UPDATE SET =Im fat )
比较特殊的是日期类型比如要写入 :: 这个时刻需要如下写
UPDATE SET = TIMESTAMP ::
注意这里使用了 TIMESTAMP 关键字并使用单引号隔开另外请注意日期格式上面的格式是可识别的Oracle 识别的格式没有 SQL Server 那般多这是和 SQL Server 不同的地方
顺便提一句Access 中的日期类型是用井号(#)隔开的UPDATE SET = # ::#
访问 Oracle 过程/函数()
SQL Server 作程序时经常使用存储过程Oracle 里也可以使用过程还可以使用函数Oracle 的过程似乎是不能有返回值的有返回值的就是函数了(这点有些像 BASIC函数/过程区分的很细致SQL Server 存储过程是可以有返回值的)
NET 访问 Oracle 过程/函数的方法很类似于 SQL Server例如
OracleParameter[] parameters = {
new OracleParameter(ReturnValue OracleTypeInt ParameterDirectionReturnValue true
DataRowVersionDefault ConvertDBNull )
new OracleParameter(参数 OracleTypeNVarChar )
new OracleParameter(参数OracleTypeDateTime)
new OracleParameter(参数OracleTypeNumber )
};
parameters[]Value = test;
parameters[]Value = DateTimeNow;
parameters[]Value = ;// 也可以是 new OracleNumber();
OracleConnection connection = new OracleConnection( ConnectionString );
OracleCommand command = new OracleCommand(函数/程名 connection);
commandCommandType = CommandTypeStoredProcedure;
foreach(OracleParameter parameter in parameters)
commandParametersAdd( parameter );
connectionOpen();
commandExecuteNonQuery();
int returnValue = parameters[]Value; //接收函数返回值
connectionClose();
Parameter 的 DbType 设定请参见 SystemDataOracleClientOracleType 枚举的文档比如Oracle 数据库中 Number 类型的参数的值可以用 NET decimal 或 SystemDataOracleClientOracleNumber 类型指定 Integer 类型的参数的值可以用 NET int 或 OracleNumber 类型指定等等
上面例子中已经看到函数返回值是用名为ReturnValue的参数指定的该参数为 ParameterDirectionReturnValue 的参数
访问 Oracle 过程/函数 ()
不返回记录集(没有 SELECT 输出)的过程/函数调用起来和 SQL Server 较为类似但如果想通过过程/函数返回记录集在 Oracle 中就比较麻烦一些了
在 SQL Server 中如下的存储过程
CREATE PROCEDURE GetCategoryBooks
(
@CategoryID int
)
AS
SELECT * FROM Books
WHERE CategoryID = @CategoryID
GO
在 Oracle 中请按以下步骤操作
()创建一个包含有一个游标类型(一个数据库中只需作一次)
CREATE OR REPLACE PACKAGE Test
AS
TYPE Test_CURSOR IS REF CURSOR;
END Test;
()过程
CREATE OR REPLACE PROCEDURE GetCategoryBooks
(
p_CURSOR out TestTest_CURSOR 这里是上面包中的类型输出参数
p_CatogoryID INTEGER
)
AS
BEGIN
OPEN p_CURSOR FOR
SELECT * FROM Books
WHERE CategoryID=p_CatogoryID;
END GetCategoryBooks;
()NET 程序中
OracleParameters parameters = {
new OracleParameter(p_CURSOR OracleTypeCURSOR ParameterDirectionOutput true
DataRowVersionDefault ConvertDBNull)
new OracleParameter(p_CatogoryID OracleTypeInt)
};
parameters[]Value = ;
OracleConnection connection = new OracleConnection( ConnectionString );
OracleCommand command = new OracleCommand(GetCategoryBooks connection);
commandCommandType = CommandTypeStoredProcedure;
foreach(OracleParameter parameter in parameters)
commandParametersAdd( parameter );
connectionOpen();
OracleDataReader dr = commandExecuteReader();
while(drRead())
{
// 你的具体操作这个就不需要我教吧?
}
connectionClose();
另外有一点需要指出的是如果使用 DataReader 取得了一个记录集那么在 DataReader 关闭之前程序无法访问输出参数和返回值的数据