设为首页收藏本站language 语言切换
查看: 1232|回复: 0
收起左侧

用C#对ADO.NET数据库完成简单操作

[复制链接]
发表于 2010-2-25 10:25:21 | 显示全部楼层 |阅读模式
<p >数据库访问是程序中应用最普遍的部分。随着C#和ADO.NET的引入,这种操作变得更简单。这篇文章将示范四种最基础的数据库操作。<p >● 读取数据。其中包括多种数据类型:整型,字符串,日期型。<p >● 写数据。如读数据一样,我们也需要写入多种类型的数据。这可以通过SQL语句来完成。<p >● 更新或修改数据。我们将再次用到SQL语句。<p >● 删除数据。用SQL实现。<p >上述的操作都要基于Microsoft Access 2000数据库,但是,我们要对连接字符串进行简单的修改才能使用SQL或其他ADO数据。<p ><center><font color="#000099"><strong>开始操作</strong></font></center><p >在使用ADO类之前,我们将把ADO.NET的命名空间和一些常用数据类包括进来。把下面的代码加入到你想进行数据库操作的地方。它的具体位置应该是命名空间行之后,类声明之前。<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>using System.Data;                      // State variables    using System.Data.ADO;                  // Database    using System.Globalization;             // Date</ccid_code></pre></td></tr></table></ccid_nobr><p >你或许还要向System.Data命名空间添加参数,这取决于工程的类型需要。你所添加的代码的编译信息会提醒你这一点。添加System.Data命名空间的操作:<p >● 右键点击Solution explorer--参数选项;<p >● 选择添加参数;<p >● 选择.NET框架栏;<p >● 双击System.data.dll条目;<p >● 选择OK;<p >● System.data应该出现在Solution explorer的参数列表中了。<p >由于在多数操作中都会使用连接字符串,所以我建议你将它包含在使用的类中。<p >注意:程序中数据库文件的路径可能和下面不一样:<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>//Attributes    public const string DB_CONN_STRING =         &amp;quot;Driver={Microsoft Access Driver (*.mdb)}; &amp;quot;+        &amp;quot;DBQ=D:\\CS\\TestDbReadWrite\\SimpleTest.mdb&amp;quot;;</ccid_code></pre></td></tr></table></ccid_nobr><p ><center><font color="#000099"><strong>读取数据</strong></font></center><p >现在的操作就比较有趣了。读是通过ADODataReader类完成的(参看Chris Maunder的文章"The ADO.NET ADODataReader CLASS" 以了解更多)。读的操作步骤如下:<p >● 用ADO连接打开数据库<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>ADOConnection conn = new ADOConnection(DB_CONN_STRING);conn.Open();</ccid_code></pre></td></tr></table></ccid_nobr><p >● 创建一个SQL语句来确认要获取的数据。这条命令执行后返回一个ADODataReader对象。注意Execute方法中的OUT关键字。这是C#中传递参数的方式。<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>ADODataReader dr;ADOCommand cmd = new ADOCommand( &amp;quot;SELECT * FROM Person&amp;quot;, conn );cmd.Execute( out dr);</ccid_code></pre></td></tr></table></ccid_nobr><p >●         循环遍历ADODataReader中的每条记录,直到完成。注意:数据被作为字符串直接返回。字段名显示了要读取的字段。<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>while( dr.Read() ){System.Console.WriteLine( dr[&amp;quot;FirstName&amp;quot;] );}</ccid_code></pre></td></tr></table></ccid_nobr><p >● 清除        <p >但是,作为优秀的程序员我们应该将代码放在try/catch/finally 中,确保我们能够控制所有意外。<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>try    {        .... the database operations ...    }    catch( Exception ex )    {        System.Console.WriteLine( &amp;quot;READING:&amp;quot; );        System.Console.WriteLine( &amp;quot;  ERROR:&amp;quot; + ex.Message );        System.Console.WriteLine( &amp;quot;  SQL  :&amp;quot; + sSqlCmd );        System.Console.WriteLine( &amp;quot;  Conn.:&amp;quot; + DB_CONN_STRING );    }    finally    {        // Close the connection        if( conn.State == DBObjectState.Open )            conn.Close();}</ccid_code></pre></td></tr></table></ccid_nobr><p ><center><font color="#000099"><strong>读取不同的数据类型</strong></font></center><p >["stuff"]通常可以返回某个类型的字符串。但是要获取一个整型或 DateTime对象,就需要列出这些数据。以一个简单的例子或是ADODataReade内建的很多例子中的一个就可以说明。例如:<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>int nOrdinalAge = dr.GetOrdinal( &amp;quot;Age&amp;quot; );    int nAge = dr.GetInt32( nOrdinalAge );    DateTime tUpdated = (DateTime)dr[&amp;quot;Updated&amp;quot;];</ccid_code></pre></td></tr></table></ccid_nobr><p >注意通过名字定位GetOrdinal字段的用法。如果字段是空的(没有填入值),上面的代码会引发一个异常。这种情况下我们用IsNull方法检验数据是否存在。<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>int nOrdinalAge = dr.GetOrdinal( &amp;quot;Age&amp;quot; );    if( dr.IsNull( nOrdinalAge ) )    {        System.Console.WriteLine( &amp;quot; Age  : Not given!&amp;quot; );    }    else    {        int nAge = dr.GetInt32( nOrdinalAge );        System.Console.WriteLine( &amp;quot; Age  : &amp;quot; + nAge );</ccid_code></pre></td></tr></table></ccid_nobr><p ><center><font color="#000099"><strong>插入,修改,删除和其他SQL命令</strong></font></center><p >插入,修改,和删除用SQL语句很容易实现。下面的代码通过一个SQL命令插入一条记录:<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>// SQL command    String sSQLCommand = &amp;quot;INSERT INTO Person (Age, FirstName,     Description, Updated)  &amp;quot; +                         &amp;quot;VALUES( 55, 'Bob', 'Is a Penguin',                         '2001/12/25 20:30:15' );&amp;quot;;    // Create the command object    ADOCommand cmdAdder = new ADOCommand(        sSQLCommand,        DB_CONN_STRING);    cmdAdder.ActiveConnection.Open();    // Execute the SQL command    int nNoAdded = cmdAdder.ExecuteNonQuery();    System.Console.WriteLine( &amp;quot;\nRow(s) Added =       &amp;quot; + nNoAdded + &amp;quot;\n&amp;quot; );</ccid_code></pre></td></tr></table></ccid_nobr><p >注意:try/catch并未出现在上述例子中,实际上是需要写的。<p ><b>插入</b><p >上述代码通过一条SQL语句插入一条记录。这条命令稍后执行。命令格式中需要注意的是:<p >● 数值直接赋值,不同单引号(');<p >● 字符串必须用单引号括起来 ('blah');<p >● 字符串中不能包含任何单引号或是双引号;<p >● 日期和时间都要以国际格式包括在单引号中。('YYYYY/MM/DD HH:MM:SS')<p ><b>修改</b><p >UPDATE命令指示了要被修和已做修改的记录。ExecuteNonQuery()返回的值显示变化的纪录的数目,这样如果在表格中有5个Peter那它就会返回5。<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>String sSQLCommand = &amp;quot;UPDATE Person SET Age = 27 WHERE FirstName = 'Peter'&amp;quot;;</ccid_code></pre></td></tr></table></ccid_nobr><p ><b>删除</b><p >DELETE命令显示要被删除的纪录。这可能会是几条。ExecuteNonQuery()返回的值显示变化的纪录的数目,这样如果表中有2个Bobo就返回2。这两个Bobo都会被删除。<p ><ccid_nobr><table align="center" border="1" bordercolordark="#FFFFFF" bordercolorlight="black" cellpadding="2" cellspacing="0" width="540"><tr><td bgcolor="e6e6e6" class="code"><pre><ccid_code>String sSQLCommand = &amp;quot;DELETE FROM Person WHERE FirstName = 'Bobo'&amp;quot;;</ccid_code></pre></td></tr></table></ccid_nobr><p ><b>关于样例程序</b><p >样例是个简单的控制程序,它执行Microsoft Access数据库中提供的所有操作。在Visual Studio.NET IDE将TestDbReadWrite.csproj 作为工程文件打开就可以编译它。在MainConsole.cs中改变DB_CONN_STRIN的值,让其指向SimpleTest.mdb,编译它。<p ><center><font color="#000099"><strong>结论</strong></font></center><p >现在你可以在C#中执行基础数据库操作了。找时间学学SQL,也要多读些有关它工作原理的文章。如果你感到厌倦了,到www.mctainsh.com上去看一下更新的代码。<p >(责任编辑 <ccid_nobr>Sunny</ccid_nobr>)                                 <p align="center"></p></p>
您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2025-4-10 13:15 , Processed in 0.065345 second(s), 22 queries , Redis On.  

  Powered by Discuz!

  © 2001-2025 HH010.COM

快速回复 返回顶部 返回列表