国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

用C#對ADO.NET數據庫完成簡單操作

2024-07-10 13:07:27
字體:
來源:轉載
供稿:網友
數據庫訪問是程序中應用最普遍的部分。隨著c#和ado.net的引入,這種操作變得更簡單。這篇文章將示范四種最基礎的數據庫操作。
  
  ● 讀取數據。其中包括多種數據類型:整型,字符串,日期型。
  
  ● 寫數據。如讀數據一樣,我們也需要寫入多種類型的數據。這可以通過sql語句來完成。
  
  ● 更新或修改數據。我們將再次用到sql語句。
  
  ● 刪除數據。用sql實現。
  
  上述的操作都要基于microsoft access 2000數據庫,但是,我們要對連接字符串進行簡單的修改才能使用sql或其他ado數據。
  
  
  開始操作
  
  
  在使用ado類之前,我們將把ado.net的命名空間和一些常用數據類包括進來。把下面的代碼加入到你想進行數據庫操作的地方。它的具體位置應該是命名空間行之后,類聲明之前。
  
  using system.data; // state variables
   using system.data.ado; // database
   using system.globalization; // date
  
  
  
  你或許還要向system.data命名空間添加參數,這取決于工程的類型需要。你所添加的代碼的編譯信息會提醒你這一點。添加system.data命名空間的操作:
  
  ● 右鍵點擊solution explorer--參數選項;
  
  ● 選擇添加參數;
  
  ● 選擇.net框架欄;
  
  ● 雙擊system.data.dll條目;
  
  ● 選擇ok;
  
  ● system.data應該出現在solution explorer的參數列表中了。
  
  由于在多數操作中都會使用連接字符串,所以我建議你將它包含在使用的類中。
  
  注意:程序中數據庫文件的路徑可能和下面不一樣:
  
  //attributes
   public const string db_conn_string =
   "driver={microsoft access driver (*.mdb)}; "+
   "dbq=d://cs//testdbreadwrite//simpletest.mdb";
  
  
  
  
  讀取數據
  
  
  現在的操作就比較有趣了。讀是通過adodatareader類完成的(參看chris maunder的文章"the ado.net adodatareader class" 以了解更多)。讀的操作步驟如下:
  
  ● 用ado連接打開數據庫
  
  adoconnection conn = new adoconnection(db_conn_string);
  conn.open();
  
  
  
  ● 創建一個sql語句來確認要獲取的數據。這條命令執行后返回一個adodatareader對象。注意execute方法中的out關鍵字。這是c#中傳遞參數的方式。
  
  adodatareader dr;
  adocommand cmd = new adocommand( "select * from person", conn );
  cmd.execute( out dr);
  
  
  
  ● 循環遍歷adodatareader中的每條記錄,直到完成。注意:數據被作為字符串直接返回。字段名顯示了要讀取的字段。
  
  while( dr.read() )
  {
  system.console.writeline( dr["firstname"] );
  }
  
  
  
  ● 清除
  
  但是,作為優秀的程序員我們應該將代碼放在try/catch/finally 中,確保我們能夠控制所有意外。
  
  try
   {
   .... the database operations ...
   }
   catch( exception ex )
   {
   system.console.writeline( "reading:" );
   system.console.writeline( " error:" + ex.message );
   system.console.writeline( " sql :" + ssqlcmd );
   system.console.writeline( " conn.:" + db_conn_string );
   }
   finally
   {
   // close the connection
   if( conn.state == dbobjectstate.open )
   conn.close();
  }
  
  
  
  
  讀取不同的數據類型
  
  
  ["stuff"]通??梢苑祷啬硞€類型的字符串。但是要獲取一個整型或 datetime對象,就需要列出這些數據。以一個簡單的例子或是adodatareade內建的很多例子中的一個就可以說明。例如:
  
  int nordinalage = dr.getordinal( "age" );
   int nage = dr.getint32( nordinalage );
   datetime tupdated = (datetime)dr["updated"];
  
  
  
  注意通過名字定位getordinal字段的用法。如果字段是空的(沒有填入值),上面的代碼會引發一個異常。這種情況下我們用isnull方法檢驗數據是否存在。
  
  int nordinalage = dr.getordinal( "age" );
   if( dr.isnull( nordinalage ) )
   {
   system.console.writeline( " age : not given!" );
   }
   else
   {
   int nage = dr.getint32( nordinalage );
   system.console.writeline( " age : " + nage );
  
  
  
  
  插入,修改,刪除和其他sql命令
  
  
  插入,修改,和刪除用sql語句很容易實現。下面的代碼通過一個sql命令插入一條記錄:
  
  // sql command
   string ssqlcommand = "insert into person (age, firstname,
   description, updated) " +
   "values( 55, 'bob', 'is a penguin',
   '2001/12/25 20:30:15' );";
   // 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( "/nrow(s) added = " + nnoadded + "/n" );
  
  
  
  注意:try/catch并未出現在上述例子中,實際上是需要寫的。
  
  插入
  
  上述代碼通過一條sql語句插入一條記錄。這條命令稍后執行。命令格式中需要注意的是:
  
  ● 數值直接賦值,不同單引號(');
  
  ● 字符串必須用單引號括起來 ('blah');
  
  ● 字符串中不能包含任何單引號或是雙引號;
  
  ● 日期和時間都要以國際格式包括在單引號中。('yyyyy/mm/dd hh:mm:ss')
  
  修改
  
  update命令指示了要被修和已做修改的記錄。executenonquery()返回的值顯示變化的紀錄的數目,這樣如果在表格中有5個peter那它就會返回5。
  
  string ssqlcommand = "update person set age = 27 where firstname = 'peter'";
  
  
  
  刪除
  
  delete命令顯示要被刪除的紀錄。這可能會是幾條。executenonquery()返回的值顯示變化的紀錄的數目,這樣如果表中有2個bobo就返回2。這兩個bobo都會被刪除。
  
  string ssqlcommand = "delete from person where firstname = 'bobo'";
  
  
  
  關于樣例程序
  
  樣例是個簡單的控制程序,它執行microsoft access數據庫中提供的所有操作。在visual studio.net ide將testdbreadwrite.csproj 作為工程文件打開就可以編譯它。在mainconsole.cs中改變db_conn_strin的值,讓其指向simpletest.mdb,編譯它。
  
  
  結論
  
  
  現在你可以在c#中執行基礎數據庫操作了。找時間學學sql,也要多讀些有關它工作原理的文章。如果你感到厭倦了,到www.mctainsh.com上去看一下更新的代碼。
中國最大的web開發資源網站及技術社區,
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 葵青区| 建湖县| 蒙山县| 黄大仙区| 北京市| 华安县| 突泉县| 洛阳市| 宁波市| 横峰县| 泾阳县| 花垣县| 岗巴县| 西乌珠穆沁旗| 三台县| 宁陕县| 如皋市| 东山县| 河曲县| 专栏| 都兰县| 梁河县| 出国| 当雄县| 苍梧县| 安国市| 新疆| 应用必备| 新疆| 台南县| 荆州市| 工布江达县| 香格里拉县| 电白县| 阿勒泰市| 通辽市| 衡水市| 民丰县| 越西县| 阜南县| 道孚县|