程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> Asp.Net、Ado.net 數據庫編程超級攻略

Asp.Net、Ado.net 數據庫編程超級攻略

編輯:.NET實例教程


Command對象中包含了提交給數據庫系統的訪問信息
OleDbCommand與SqlCommand對象,它們的基本對象與操作方法是相同的,在此僅介紹OleDbCommand的用法,SqlCommand的用法類推即可。
最常用初始化Command對象的方法是在建立Command實例中帶入兩個參數
OleDbCommand myComm=new OleDbCommand(strQuery,myConnection);
strQuery為SQL語句或儲存過程名,myConnection是建立的Connection對象實例
Command對象主要的屬性有
Connection:
CommandText:設置或獲取Command對象使用的Connection對象實例
CommandType:StoredProceduce、TableDirect、Text(標准SQL語句)
Parameters:取得參數值集合
ExecuteReader:執行CommandText指定的SQL語句或儲存過程名,返回類型為DataReader
ExecuteNonQuery:與ExecuteReader功能相同,只是返回值為執行SQL語句或儲存過程受影響的記錄行數
DataReader--SqlDataReader、OleDbDataReader
FIEldCount:顯示當前操作記錄的字段總和
IsClosed:判斷DataReader是否關閉
Close:關閉DataReader
GetString:以String返回指定列中的值
GetValue:以自身的類型返回指定列中的值
GetValues:返回當前記錄所有字段的集合
Read:讀下一條記錄
例:
<% @ Page Language="C#" %>
<% @ Import Namespace="System.Data"%>
<% @ Import Namespace="System.Data.OleDb"%>
-------------------------------------------
<% @ Import Namespace="System.Data.SqlClIEnt"%>
<Script Language="c#" Runat="Server">
OleDbDataReader dr;

String myconnstring="Provider=Microsoft.Jet.OLEDB.4.0; DataSource="+Server.MapPath(".")+"..\mdb";
string sql=".."
OleDbConnection my_conn=new OleDbConnection(myconnstring);
OleDbCommand my_comm=new OleDbCommand(sql,my_conn);
my_comm.Connection.Open();
dr=my_comm.ExecuteReader();
//DataGrid dg
dg.DataSource=dr
dg.DataBind();
</Script>
<head>
<% while(dr.Read())
 ...{;}
%>
</head> 
DataSet DataAdapter
DataAdapter是與DataSet配套使用的
OleDbDataAdapter my_adapter=new OleDbDataAdapter();
-------------------------------------------------
SqlDataAdapter my_sqladapter=new SqlDataAdapter();
my_adapter.SelectCommand.Connection=my_conn;

my_adapter.UpdateCommand.Connection=my_conn;
my_adapter.DeleteCommand.Connection=my_conn;
my_adapter.InsertCommand.Connection=my_conn;
如果需要執行Sql語句,那麼還必須給相應的CommandText屬性賦值。http://sucai.knowsky.com/
my_adapter.SelectCommand.CommandText=strSelect;
my_adapter.UpdateCommand.CommandText=strUpdate;
my_adapter.InsertCommand.CommandText=strInsert;
my_adapter.DeleteCommand.CommandText=strDelete;
如果只是查詢數據庫,則可以建立DataAdapter實例時就完成上述工作
OleDbDataAdapter MyAdapter=new OleDbDataAdapter(sql,my_conn);
DataSet ds=new DataSet();
OleDbConnection my_conn=new OleDbConnection(myconnstring);
OleDbDataAdapter my_adapter=new OleDbDataAdapter(sql,my_conn);
my_adapter.fill(ds,"score");
DataGrid score;
score.DataSource=ds.Table["score"].DefaultvIEw;
score.DataBind();
//InsertCommand
DataRow dr=ds.Table["Score"].NewRow();
dr["name"]=..

ds.Tables["Score"].Rows.Add(dr);
//update
DataAdapter.Update(ds,"Score");
//modify
DataRow dr=ds.Tables["Score"].Rows[0];
dr["name"]=;
//Delete
DataRow dr=ds.Talbes["Score"].Rows[0];
dr.Delete();
//注:
OleDbConnection my_conn=new OleDbConnection(myconnstr
ing);
OleDbDataAdapter my_adapter=new OleDbDataAdapter(sql,my_conn);
OleDbCommandBuilder custCB=new OleDbCommandBuilder(my_adapter);//DataAdapter在數據發生改變時,並不能自動產生(Transact- SQL),所以一定要使用CommandBuilder,它能自動產生Sql語句,!就此一步
RejectChanges是DataSet,DataTable,DataRow共有的方法
使操作對象拒絕已經發生的改變,使數據復員
if(DataSet.HasErrors)
...{
 
 DataSet.RejectChanges();
}
else...{ DataSet.AcceptChanges();}
----------------------------------------------------------------------------------------------------------------------------------
DataReader->DataTable
  public static DataTable ConvertDataReaderToDataTable(SqlDataReader dataReader)
  ...{
   /**//**//**////定義DataTable和模式
   DataTable datatable = new DataTable();
   DataTable schemaTable = dataReader.GetSchemaTable(); //導入一個數據表的表結構  
   
   try
   ...{ /**//**//**////動態添加表的數據列
    foreach(DataRow myRow in schemaTable.Rows)
    ...{
     DataColumn myDataColumn = new DataColumn();
     myDataColumn.DataType = myRow.GetType();
     myDataColumn.ColumnName = myRow[0].ToString();
     datatable.Columns.Add(myDataColumn);
    }
    
    /**//**//**////添加表的數據
    while(dataReader.Read())
    ...{
     DataRow myDataRow = datatable.NewRow();
     for(int i=0;i<schemaTable.Rows.Count;i++)
     ...{
      myDataRow[i] = dataReader[i].ToString();
     }
     datatable.Rows.Add(myDataRow);
     myDataRow = null;
    }
    schemaTable = null;
    
    /**//**//**////關閉數據讀取器
    dataReader.Close();
    return datatable;
   }
   catch(Exception ex)
   ...{
    /**//**//**////拋出類型轉換錯誤
    SystemError.SystemLog(ex.Message);
    throw new Exception(ex.Message,ex);
   }   
  }
 }
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved