网站首页 > 网络编程教程 > ASP.NET教程 > Asp.Net、Ado.net 数据库编程超级攻略

Asp.Net、Ado.net 数据库编程超级攻略

  • 作者:互联网
  • 时间:2009-07-01 16:45:38

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="Sy***m.Data"%>
<% @ Import Namespace="Sy***m.Data.OleDb"%>
-------------------------------------------
<% @ Import Namespace="Sy***m.Data.SqlClient"%>


<% while(dr.Read())
 ...{;}
%>

DataSet DataAdapter
DataAdapter是与DataSet配套使用的
OleDbDataAdapter my_adapter=new OleDbDataAdapter();
-------------------------------------------------
SqlDataAdapter my_sqladapter=new SqlDataAdapter();
my***apter.SelectCommand.Connection=my_conn;

my***apter.UpdateCommand.Connection=my_conn;
my***apter.DeleteCommand.Connection=my_conn;
my***apter.InsertCommand.Connection=my_conn;
如果需要执行Sql语句,那么还必须给相应的CommandText属性赋值。http://sucai.downcodes.com/
my***apter.SelectCommand.CommandText=strSelect;
my***apter.UpdateCommand.CommandText=strUpdate;
my***apter.InsertCommand.CommandText=strInsert;
my***apter.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***apter.fill(ds,"score");
DataGrid score;
sc***.DataSource=ds.Table["score"].Defaultview;
sc***.DataBind();
//InsertCommand
DataRow dr***.Table["Score"].NewRow();
dr["name"]=..

ds***bles["Score"].R***.Add(dr);
//update
Da***dapter.Update(ds,"Score");
//modify
DataRow dr***.Tables["Score"].Rows[0];
dr["name"]=;
//Delete
DataRow dr***.Talbes["Score"].Rows[0];
dr***lete();
//注:
OleDbConnection my_conn=new OleDbConnection(myconnstring);
OleDbDataAdapter my_adapter=new OleDbDataAdapter(sql,my_conn);
OleDbCommandBuilder custCB=new OleDbCommandBuilder(my_adapter);//DataAdapter在数据发生改变时,并不能自动产生(Transact- SQL),所以一定要使用CommandBuilder,它能自动产生Sql语句,!就此一步
RejectChanges是DataSet,DataTable,DataRow共有的方法
使操作对象拒绝已经发生的改变,使数据复员
if(Da***et.HasErrors)
...{
 
 Da***et.RejectChanges();
}
else...{ Da***et.AcceptChanges();}
----------------------------------------------------------------------------------------------------------------------------------
DataReader->DataTable
  public static DataTable ConvertDataReaderToDataTable(SqlDataReader dataReader)
  ...{
   /**//**//**////定义DataTable和模式
   DataTable datatable = new DataTable();
   DataTable schemaTable = da***eader.GetSchemaTable(); //导入一个数据表的表结构 
  
   try
   ...{ /**//**//**////动态添加表的数据列
    foreach(DataRow myRow in sc***aTable.Rows)
    ...{
     DataColumn myDataColumn = new DataColumn();
     my***aColumn.DataType = my***.GetType();
     my***aColumn.ColumnName = myRow[0].ToString();
     da***able.Columns.Add(myDataColumn);
    }
   
    /**//**//**////添加表的数据
    while(da***eader.Read())
    ...{
     DataRow myDataRow = da***able.NewRow();
     for(int i=0;i<sc***aTable.Rows.Count;i++)
     ...{
      myDataRow[i] = dataReader[i].ToString();
     }
     datatable.R***.Add(myDataRow);
     myDataRow = null;
    }
    schemaTable = null;
   
    /**//**//**////关闭数据读取器
    da***eader.Close();
    return datatable;
   }
   catch(Exception ex)
   ...{
    /**//**//**////抛出类型转换错误
    Sy***mError.SystemLog(ex***ssage);
    throw new Exception(ex***ssage,ex);
   }  
  }
 }
}