1、Access里使用存储过程。

  这可能是一个很有意思的内容,我所以这样做,是因为明确的知道自己做的项目会以SQLServer上实现,而在测试及开发的时候,还只能用Access,这或许是一个矛盾,但我还是把数据层与逻辑尽可能的分开了,也实现了数据可以快速转化的一些方法。但我还是想用SQLserver的存储过程,于是在Access里做了这样的方法来代替。

先在Access的查询里建立一个查询,因为我们可以使用任何的SQL语句在这个查询里,所以也就可以使用一些数据库操作命令了,然后保存。在ASP.net里这样来引用它:

//t_video_SumVideos:  "select count(v_id),sum(v_size) from t_video where v_clientID=?";
if(OpenConn())
   {
    m_command     = new OleDbCommand();

    m_command.CommandType  = CommandType.StoredProcedure;
 m_command.CommandText  = "t_video_SumVideos";
    m_command.Parameters.Add("@int_clientID",m_clientID);
    OleDbDataReader m_reader;
    m_reader    = m_command.ExecuteReader();
    if(m_reader.Read())
    {
     m_ExistsVideos  = m_reader.GetInt32(0);
     m_ExistsSize  = m_reader.GetInt64(1);
    }
    m_reader.Close();
   }

因为参数名只能用?(书上这样说的,没有试过其它的变量名)所以,我们必须自己小心的修理变量的传递顺序。对于数值与字符串,使用的时候都没有问题,日期时间变量得用一个ToString()来转化一下,不过还好,都能使用。
 m_command.Parameters.Add("@int_clientID",m_clientID);
这里的“@int_clientID”没有什么用,自己定义的,但为了方便的转到SQLServer上,还我是准备了一下。

2、在自己定义的控件里使用参数:

有这样的一个例子:HeaderTitle.ascx
<script runat= “server“>
public PageTitle as stirng =”Title”
</Script>
<title><%=PageTitle%></title>

这一个简化的控件,里面用了一个参数(VB.net语法,我没有试过)。而且在自己引用空上控件的时候:
<%@Register TagePerfix=“Company“ TagName=“Header“ Src=“HeaderTitle.ascx“%>
<Company:Header
ID=“someID“
PageTitle=“NewTitle“ runat=“server“>

我在第一次看这个例子的时候觉得很有意思,不仅可以像ASP那样使用包含文件,而且还可以使用参数。然而问题是:它没有使用CodeBehind技术,而且这本质上也没有把代码也逻辑分开,里面还是与HTML混用,而更多的是,如果我有很多的参数想要从数据库里取得,而且给控件加一些自己的事件,都将变得很麻烦(在没有使用CodeBehind技术的时候)。

于是我这样想办法:

//自己的控件:
namespace WAVE
{
 using System;
 using System.Data;
 using System.Drawing;
 using System.Web;
 using System.Web.UI.WebControls;
 using System.Web.UI.HtmlControls;
 using Webb.WAVE.Controls;
 using Microsoft.Web.UI.WebControls; /// <summary>
 ///  Summary description for inc_ClientDetialInfo.
 /// </summary>
 public class inc_ClientDetialInfo : System.Web.UI.UserControl
 {  
  private void Page_Load(object sender, System.EventArgs e)
  {
   // Put user code to initialize the page here
  }  public void LoadClientData(int m_clientID)
  {
//从数据库取得数据
   m_client  = new ClientAccount();
   m_client.LoadClientData(m_clientID);
   Label1.Text  = m_client.m_address;
  }
}而在引用它的地方这样加载它,这样一来不仅解决了大量数据做为参数的问题,还可以让控件独立动作(上面省略了)。
//这一个在DataGrid里选择了某一个数据后,通过ID在到数据库里查询更详细的内容,然后动态的加载到页面的一个Panel上.
  private void DataGrid1_SelectedIndexChanged(object sender, System.EventArgs e)
  {   int m_clientID     = Convert.ToInt32(DataGrid1.DataKeys[DataGrid1.SelectedIndex]);//取得ID
   c_clientDetailPanel.Visible  = true;//显示Panel
   c_dynamicDetialPanel.Visible = true;//
   m_cilentDetia     = (inc_ClientDetialInfo)this.LoadControl("inc_ClientDetialInfo.ascx");//动态加载控件m_clientData在前面已经申明,inc_ClientDetialInfo是自己定义的一个控件类名.
   m_cilentDetia.LoadClientData(m_clientID);//调用自己控件的方法,让它自己从数据库里加载信息
   c_dynamicDetialPanel.Controls.Add(m_cilentDetia);//在页面上显示自己加载的详细信息
  }

OK,这样一来解决了我的很多麻烦的问题,方便快捷的使用方法。