public DataSet GetOrderBySearch(string keyword,int column)
{
SqlConn.SqlConn db=new SqlConn.SqlConn();
DataSet ds=null;
SqlParameter[] prams={
 db.MakeInParam("@keyword",SqlDbType.VarChar,100,keyword),
 db.MakeInParam("@column",SqlDbType.Int,4,column)
 };
db.RunProc("sp_GetOrderBySearch",prams,out ds);
return ds;
}public static DataSet GetOrderBySearch(string keyword,int column)
{
SqlConn.SqlConn db=new SqlConn.SqlConn();
DataSet ds=null;
SqlParameter[] prams={
 db.MakeInParam("@keyword",SqlDbType.VarChar,100,keyword),
 db.MakeInParam("@column",SqlDbType.Int,4,column)
 };
db.RunProc("sp_GetOrderBySearch",prams,out ds);
return ds;
}上面一个是静态方法一个不是,我想问一下这两者之间有什么区别
下面的代码会用到上面的方法
private void btn_search_Click(object sender, System.EventArgs e)
{
DataSet ds=null;
ygmis.Components.Order order=new ygmis.Components.Order();
ds=order.GetOrderBySearch(txt_keyword.Text,Int32.Parse(dpl_column.SelectedValue.ToString()));
dg_order.DataSource=ds.Tables[0].DefaultView;
dg_order.DataBind();
}但如果是使用的静态方法dg_order的结果为空,非得用非静态方法dg_order中才会有数据
这是为什么请详解!~谢谢!~

解决方案 »

  1.   

    方法或者函数分 静态方法与实例方法,静态方法属于类所有,实例方法属于类的对象所有,也就是说,你调用的时候,如果是静态的,必须要 类去调用,实例的就用类的对象调用,上面的程序,你的order是ygmis.Components.Order 类的一个对象,所以结果就是你上面提到的!
      

  2.   

    但有时候使用静态方法却又能使DataGrid得到数据,这是为什么?