当前位置:首页 > 数据库 >

Oracle完全学习手册

PDF影印版

时间:2020-11-19 09:43:59大小:95 MB已被193人关注 资源下载

黎文轩
黎文轩

oracle数据库作为世界范围内性能*异的数据库系统之一,它在国内数据库市场的占有率远远超过其对手,始终处于数据库领域的领先地位。本书以oracle 11g for windows xp为平台,由浅入深地介绍oracle database 11g系统的使用方法和基本管理。主要包括:关系数据库设计、oracle数据库的基本体系结构、存储管理、管理控制文件和日志文件、sql语言基础、使用sql*plus、pl/sql程序设计、存储过程、触发器和程序包、表、模式对象管理、安全管理以及基本的备份与恢复等,最后以4个应用实例分别结合java swing、jsp、asp.net和php技术来讲述oracle的实际应用。

Oracle完全学习手册》适合大专院校在校学生、网站开发人员、java学习和开发人员以及编程爱好者学习和参考。

目录

  • 第一篇 oracle基础篇
  • 第1章 oracle关系数据库
  • 1.1 关系数据模型
  • 1.1.1 二维表
  • 1.1.2 关系术语
  • 1.1.3 关系数据模型的特点
  • 1.2 关系数据库
  • 1.2.1 关系操作
  • 1.2.2 关系的完整性
  • 1.3 关系数据库规范化理论
  • 1.3.1 函数依赖
  • 1.3.2 范式理论
  • 1.4 数据库设计
  • 1.4.1 实体-关系模型
  • 1.4.2 e-r图的绘制
  • 1.4.3 将e-r数据模型转化为关系模式
  • 1.5 oracle应用系统结构
  • 1.5.1 单磁盘独立主机结构
  • 1.5.2 多磁盘独立主机结构
  • 1.5.3 多数据库独立主机结构
  • ……
  • 第二篇操作Oracle篇
  • 第三篇Oracle进阶篇
  • 第四篇备份与恢复篇
  • 第五篇综合应用篇
已被760人点赞
asp.net中oracle 存储过程(图文)
asp.net中oracle 存储过程(图文)

在大型数据库系统中,存储过程和触发器具有很重要的作用。无论是存储过程还是触发器,都是SQL 语句和流程控制语句的集合。

ORACLE代码

CREATE OR REPLACE PROCEDURE gd_CURSOR(MYCS1 OUT SYS_REFCURSOR,MYCS2 OUT SYS_REFCURSOR,a out varchar)as
BEGIN
 a:='test';
 OPEN MYCS1 FOR
 SELECT 1 from dual;
 OPEN MYCS2 FOR
 SELECT 2 from dual;
END;

C#代码

/// <summary>
 /// 执行oracle存储过程返回多个结果集
 /// </summary>
 /// <param name="strProcName">存储过程名称</param>
 /// <param name="ResultCount">返回个数</param>
 /// <param name="paras">参数</param>
 /// <returns>任意对象数组</returns>
 public object[] ExcuteProc_N_Result(string strProcName, int ResultCount, params OracleParameter[] paras)
 {
  using (OracleConnection conn = new OracleConnection("User ID=用户名;Password=密码;Data Source=数据库;"))
  {
  OracleCommand cmd = new OracleCommand(strProcName, conn);
  if (paras != null && paras.Length > 0)
  {
   for (int j = 0; j < paras.Length; j++)
   {
   if (paras[j].Value == null)
   {
    paras[j].Value = DBNull.Value;
   }
   }
  }
  cmd.Parameters.AddRange(paras);
  cmd.CommandType = CommandType.StoredProcedure;
  conn.Open();
  cmd.ExecuteNonQuery();
  int i = 0;
  //int nOutputParametersCount = 0;
  object[] objResult = new object[ResultCount];
  foreach (OracleParameter p in cmd.Parameters)
  {
   if (p.Direction == ParameterDirection.Output || p.Direction == ParameterDirection.InputOutput)
   {
   if (p.Value is OracleDataReader)
   {
    OracleDataReader reader = p.Value as OracleDataReader;
    objResult[i++] = ConvertDataReaderToDataTable(reader);
   }
   else
   {
    objResult[i++] = p.Value;
   }
   }
  }
  return objResult;
  }
 }
 /// <summary> 
 /// 将DataReader 转为 DataTable 
 /// </summary> 
 /// <param name="DataReader">OleDbDataReader</param> 
 protected DataTable ConvertDataReaderToDataTable(OracleDataReader reader)
 {
  DataTable objDataTable = new DataTable("TmpDataTable");
  try
  {
  int intFieldCount = reader.FieldCount;//获取当前行中的列数;
  for (int intCounter = 0; intCounter <= intFieldCount - 1; intCounter++)
  {
   objDataTable.Columns.Add(reader.GetName(intCounter), reader.GetFieldType(intCounter));
  }
  //populate datatable 
  objDataTable.BeginLoadData();
  //object[] objValues = new object[intFieldCount -1]; 
  object[] objValues = new object[intFieldCount];
  while (reader.Read())
  {
   reader.GetValues(objValues);
   objDataTable.LoadDataRow(objValues, true);
  }
  reader.Close();
  objDataTable.EndLoadData();
  return objDataTable;
  }
  catch (Exception ex)
  {
  throw new Exception("转换出错出错!", ex);
  }
 }

调用方法

OracleParameter[] oracleParameter = new OracleParameter[]{
new OracleParameter("MYCS1",OracleType.Cursor),
new OracleParameter("MYCS2",OracleType.Cursor),
new OracleParameter("a",OracleType.VarChar,200),
};
oracleParameter[0].Direction = ParameterDirection.Output;
oracleParameter[1].Direction = ParameterDirection.Output;
oracleParameter[2].Direction = ParameterDirection.Output;

object[] xxx = ExcuteProc_N_Result("gd_CURSOR", 3, oracleParameter);

以上内容是通过代码介绍了asp.net中oracle存储过程。

接下来通过第二种的方式在给大家介绍下oracle存储过程(图文)。

请看下面方法、步骤

第一步:通过ORACLE自带的 Net Manager 配置需要连接的数据库,如COST

asp.net中oracle 存储过程(图文)

第二步:打开PL/SQL数据库工具,属于正确的用户名和密码以及选择,点击OK进入需要创建存储过程的用户下

asp.net中oracle 存储过程(图文)

第三步:了解一般存储过程的格式

create or replace procedure 存储过程名(param1 in type,param2 out type)
as
变量1 类型(值范围);
变量2 类型(值范围);
Begin
   语句块
Exception --异常处理
   When others then
      Rollback;
End;

asp.net中oracle 存储过程(图文)

第四步:在SQL输入界面输入需需要创建的存储过程

create or replace procedure sp_demo(param1 in varchar2,param2 out varchar2)
/*
* 存储过程实例
*/
as
cnt int;
rst varchar2(100)
Begin
 Select count(*) into cst from Tab_Demo where Col_Value = param1;
 If (cst > 0) then --判断条件
 param2 := '有匹配的值';
 Else
 param2 := '无匹配的值';
 End if;
Exception
 When others then
 Rollback;
End;

如下图

asp.net中oracle 存储过程(图文)

第五步:测试刚才编写的存储过程

exec sp_demo('男');

asp.net中oracle 存储过程(图文)

END

注意事项

不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程

如果用create or replace procedure,创建存储过程的时候注意不要与用户下现有的存储过程同名,造成现在存储过程被覆盖
存储过程参数不带取值范围,in表示传入,out表示输出

以上通过两种方式介绍哦oracle存储过程,希望对大家有所帮助。

已被351人点赞
下载地址:百度网盘下载
相关资源
Oracle PL/SQL 程序设计(上下册)
Oracle PL/SQL 程序设计(上下册) 第6版 立即下载
Oracle Database 11g RAC手册
Oracle Database 11g RAC手册 超清第2版 立即下载
Oracle SQL疑难解析
Oracle SQL疑难解析 影印版 立即下载
SQL优化最佳实践:构建高效率Oracle数据库的方法与技巧
SQL优化最佳实践:构建高效率Oracle数据库的方法与技巧 高清版

SQL是重要的关系数据库操作语言。SQL语句的运行效率,对于数据库的整体性能至关重要。因此,SQL语句的优化就成为数据库专业人员必须掌握的一门技能。作为一个长期从事数据库工作的技术

立即下载
名师讲坛:Oracle SQL入门与实战经典
名师讲坛:Oracle SQL入门与实战经典 超清扫描版

小说式Oracle从入门到精通,附教学讲义,适合10g/11g/12c,通过例子来解释复杂的计算机和数据库概念,是一本Oracle SQL的实用入门教材

立即下载
Oracle 12c从入门到精通
Oracle 12c从入门到精通 第二版

本书研究了堤坝渗漏探测中获取水文地质参数的理论和方法,重点探讨了地下水渗透流速、流向以及含水层渗透系数等参数的获取,自主研发了野外测量系统,并结合实践分析了综合示踪方法

立即下载
深度解析Oracle实战与提高
深度解析Oracle实战与提高 清晰扫描版

本书覆盖面广,从数据库基础开始,到RAC、DataGuard、GoldenGate的安装配置,再到较高级的性能调整、故障处理、系统容灾都有涉及,可以说适合各个学习阶段

立即下载

Copyright 2018-2020 www.xz577.com 码农之家

版权投诉 / 书籍推广 / 赞助:520161757@qq.com