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

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 Dot NET,C#,ASP,VB 』 → C#快餐-17 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 2165 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: C#快餐-17 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18406
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 C#快餐-17


    发信人: nice (春天), 信区: DotNET        
    标  题: C#快餐-17
    发信站: BBS 水木清华站 (Thu Jul 26 02:20:53 2001)


    Lesson 17. Reading a database.


    ADO API's are part of  the System.Data.ADO namespace. Bellow I show a very  
    simple Microsoft Access database called Bank_customer_data. The program needs
    to be compiled with option /r:System.dll /r:System.Data.dll.

    I store table Bank_customer_data in a database db2.mdb located in the  
    directory C\Temp. Firstly we would like to read a name and the amount of  
    assets of all customers of the bank. To do that we can use SQL commands  
    SELECT Name, Assets FROM Bank_customer_data. To prepare for data retrieval
    from the database, we create an instance of ADOCommand class. ADOCommand  
    class takes care of passing queries to the database. ADOCommand instance  
    can be creates by passing the address of the data source as well as the  
    name of the table as string parameters. We will write a slightly longer  
    but more transparent code. We also need an instance of ADOConnection  
    which represents an open connection to the database. We use ADOConnection  
    constructor which takes a string containing the address of the database file.

    After an instance of the ADOConnection is created we need to open the
    connection to the database using method Open(). If the connection is already  
    open an InvalidOperationException  is raised. At the end of the session we  
    call Close() to close the connection. If you try to close the connection  
    twice it generates  InvalidOperationException. The instance of ADOCommand  
    needs to be associated with an instance of opened ADOConnection.  
    This is done with the property ActiveConnection. The simplest way to pass  
    the query to the database is to with an instance of ADODataReader class.  
    The result of the query to the database is contained in the instance of  
    the ADODataReader class. To associate the instance of ADODataReader  
    with the address of the database and the query to be made, we call Execute
    method which takes the instance of the ADODataReader as an out parameter.
    The actual reading can be done line by line with the call Read().  
    If you decide to display the line you have just read, it is your responsibility to use t
    he correct data extraction methods. If, for example you are trying to
    extract a string with GetInt32() method an exception will be raised.  
    Finally, the reader is closed when no longer used.



    using System;
    using System.Data.ADO;
    public class Test{
        public static void Main()
        {
        string source = "Provider=Microsoft.JET.OLEDB.4.0;" + "data     source="
    "C:\\Winnt\\Profiles\\Administrator\\Personal\\db2.mdb
        string command="SELECT Name, Assets FROM Bank_customer_data";
        ADOCommand mCommand = new ADOCommand();
        ADOConnection mConnection=new ADOConnection(source);
        mConnection.Open();
        mCommand.ActiveConnection=mConnection;
        mCommand.CommandText=command;
        ADODataReader mReader;
        mCommand.Execute(out mReader);
        // Use Read to  read data line by line.
        while (mReader.Read())
            { //The data is extracted with the methods GetString and GetInt32
            Console.WriteLine(mReader.GetString(0) + ":" + mReader.GetInt32(1));

            }
        // Close the Reader when done.
        mReader.Close();
        // Close the connection when done.
        mConnection.Close();
        }
    }

    --

    ※ 修改:·walts 於 Jul 26 10:39:15 修改本文·[FROM: 166.111.142.118]
    ※ 来源:·BBS 水木清华站 smth.org·[FROM: 166.111.176.234]
    上一篇
    返回上一页
    回到目录
    回到页首
    下一篇


       收藏   分享  
    顶(0)
      




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

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

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

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/11/9 2:25: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的博客广告
    2024/5/3 10:27:58

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

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