日期:2009-01-10 浏览次数:21381 次
6).数据帮定控件
    ASP+中,不仅可以帮定到数据库,还可以帮定到简单的属性集合,甚至方法调用的结果,如:
    CustomerID: <%# custID %>
    <ASP:ListBox id="List1" datasource='<%# myArray %>' runat="server">
    <%# (Customer.FirstName + Customer.LastName)%>
    <%# GetBalance(CustID) %>
    看起来跟ASP中的<%=%>一样,但是ASP是用Response.Write来替换的,而ASP+则是在DataBind()
方法调用后才帮定的。数据帮定控件和Page对象都有DataBind()方法。
    注意,ASP+是强类型的,所以:
        <%# count.ToString() %>才对。
    。DataBinder.Eval()
    一个静态方法,由ASP+支持,允许后帮定的数据帮定表达式,而且还可选地转化为串,可以
用于模板。如不用Eval,则像:
    <%# String.Format("{0:c}",((DataRowView)Container.DataItem)["SomeInteger"]) %>
    可以用Eval:
    <%# DataBinder.Eval(Container.DataItem,"someinteger","{0:c}") %>
    
7).服务器方数据访问
    。连接、命令和数据集(DataSets)
    NGWS提供了一系列受管数据访问API,引入名称空间:
    <%@ Import Namespace="System.Data" %>
    <%@ Import Namespace="System.Data.SQL" %>
    a).生成SQLConnection
    b).构造SQLDatasetCommand
    c).FillDataSet
    如果是插入等操作,则用SQLCommand替换SQLDataSetCommand.
    记住:始终在用完连接后关闭连接!否则要等到页面被释放时才会被垃圾回收机制释放资源。
    。帮定数据到DataGrid,例:
        ....
        DataSet ds = new DataSet();
        myCommand.FillDataSet(ds,"Authors");
        MyDataGrid.DataSource = ds.Tables["Authors"].DefaultView;
        MyDataGrid.DataBind();
        
    。参数化查询
        SQLDataSetCommand支持参数,"@"作为参数前缀,例:
        
        myCommand.SelectCommand.Parameters.Add(new SQLParameter("@state",SQLDataType.VarChar,2));
        myCommand.SelectCommand.Parameters["@state"].Value=newValue;
        
    注意,如果DataGrid要在客户与服务器间轮转的话,一定要把MaintainState属性设置为false,
否则,性能受到影响,如:
    <ASP:DataGrid id="myDataGrid" runat="server"
    MaintainState="false"/>
    
    。插入数据
    应当保证不为null,可以使用try/catch块。
    例:
    String insertcmd = "insert into Authors values(@id,@lname)"
    SQLCommand myc = new SQLCommand(insertcmd,myConn);
    myc.Parameters["@id"].Value=cu_id.Value;
    myc.Parameters["@lname"].Value=au_lname.Value;
    myc.ActiveConnection.Open();
    try{
        myc.Execute();
    }catch(SQLException e){
        if (e.Number==2627)
        ......//主键重复
        }
    myc.ActiveConnection.Close();
    
    。更新记录
    DataGrid提供了一些内在支持,有一个整型属性,EditItemIndex,表示哪一行可以编辑,一但设置,
该行的文本输入框显示,而不是却省的静态文本,如为-1则表示没有行可以编辑。
    DataGrid可以包含一个控件,EditCommandColumn,它将为DataGrid引发