新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 Dot NET,C#,ASP,VB 』 → 在C#中使用OLEDB.NET数据提供程序通过Oracle存储过程填充数据集 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 4205 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 在C#中使用OLEDB.NET数据提供程序通过Oracle存储过程填充数据集 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18407
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 在C#中使用OLEDB.NET数据提供程序通过Oracle存储过程填充数据集


    发信人: Nineteen (-_-#!), 信区: DotNET
    标  题: 在C#中使用OLEDB.NET数据提供程序通过Oracle存储过程填充数据集
    发信站: BBS 水木清华站 (Fri Nov  7 08:26:15 2003), 转信

    本文引用下面的 Microsoft .NET 框架类库名称空间:
    System.Data.OleDb  
    本任务的内容
    概要

    要求
    在 Oracle 数据库中创建包的步骤
    创建 Visual C# .NET 应用程序的步骤
    参考
    概要
    本文演示如何使用 Oracle 存储过程产生的结果集填充 DataSet 对象。在使用 ADO.NET 支持断开连接的、分布式的数据方案时,DataSet(数据集)对象是关键所在。数据集是数据在内存中的表示形式,它提供了一致的关系编程模型,而不用关心数据源的位置。数据集表示完整的一组数据,包括相关的表、约束以及各表之间的关系。  

    返回页首
    要求
    下面的列表列出了推荐使用的硬件、软件、网络结构以及所需的 Service Pack:
    Microsoft Windows XP、Windows 2000 或 Windows NT 4.0 Service Pack 6a  
    Microsoft Data Access Components (MDAC) 2.6 或更新版本
    Oracle 8.0 Server 或更新版本
    Microsoft Visual Studio .NET  
    安装在客户机上的 Oracle Client
    本文假定您熟悉以下主题:
    Oracle 中的数据定义语言 (DDL) 查询
    Visual C# .NET 语法
    ActiveX 数据对象 (ADO)
    返回页首
    在 Oracle 数据库中创建包的步骤
    使用以下代码创建名为 Person 的表: CREATE TABLE person
    (ssn     NUMBER(9) PRIMARY KEY,
    fname   VARCHAR2(15),
    lname   VARCHAR2(20));

    INSERT INTO person VALUES(555662222,'Sam','Goodwin');

    INSERT INTO person VALUES(555882222,'Kent','Clark');

    INSERT INTO person VALUES(666223333,'Sally','Burnett');

    COMMIT;
    使用以下代码创建包的头文件: CREATE OR REPLACE PACKAGE packperson
    AS
    TYPE tssn is TABLE of  NUMBER(10)
    INDEX BY BINARY_INTEGER;
    TYPE tfname is TABLE of VARCHAR2(15)
    INDEX BY BINARY_INTEGER;
    TYPE tlname is TABLE of VARCHAR2(20)
    INDEX BY BINARY_INTEGER;

    PROCEDURE allperson
    (ssn    OUT     tssn,
    fname  OUT     tfname,
    lname  OUT     tlname);
                
    END packperson;

              /  
    使用以下代码创建包的主体: CREATE OR REPLACE PACKAGE BODY packperson
    AS

    PROCEDURE allperson
    (ssn    OUT     tssn,
    fname  OUT     tfname,
    lname  OUT     tlname)
    IS
    CURSOR person_cur IS
    SELECT ssn, fname, lname
    FROM person;

    percount NUMBER DEFAULT 1;

    BEGIN
    FOR singleperson IN person_cur
    LOOP
    ssn(percount) := singleperson.ssn;
    fname(percount) := singleperson.fname;
    lname(percount) := singleperson.lname;
    percount := percount + 1;
    END LOOP;
    END;

    END;
             /  
    返回页首
    创建 Visual C# .NET 应用程序的步骤
    新建一个 Visual C# Windows 应用程序项目。默认情况下会将 Form1 添加到项目中。
    将 DataGrid 控件和一个 Button 控件拖到 Form1 上。DataGrid1 和 Button1 默认添加到 Form1。
    将以下代码添加到代码窗口的第一行"using System.Data"之后: using System.Data.OleDb;
    将以下代码添加到 Button1_Click 事件: OleDbConnection cnOra = new OleDbConnection("Provider=MSDAORA;Data Source=myOracleServer;"  
    + "user id=myUID;password=myPWD;"
    + "persist security info=false;");
    OleDbCommand cmdPerson = new OleDbCommand
    + ("{call PackPerson.allPerson({resultset 3, ssn, fname, lname})}", cnOra);
                    OleDbDataAdapter daPerson = new OleDbDataAdapter(cmdPerson);

    cnOra.Open();

    DataSet ds = new DataSet();
    daPerson.Fill(ds,"Person");
    this.dataGrid1.DataSource = ds.Tables["Person"];

    cnOra.Close();
    按 F5 键生成并运行该应用程序。
    单击 Button1。注意结果显示在 DataGrid 控件中。
    备注:由于只有 Oracle 8.0 和更新版本支持结果集的检索和存储过程的执行,因此必须使用 Oracle 8. x 服务器运行此应用程序。  
    --
    ——长夜漫漫,无心睡眠……难道狼妹妹也睡不着吗?


    ※ 来源:·BBS 水木清华站 smth.org·[FROM: 202.206.3.3]
    返回上一页
    回到目录
    回到页首
    下一篇


       收藏   分享  
    顶(0)
      




    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/11/9 2:26:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给Google AdSense  访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/7/22 5:48:39

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    62.500ms