7/5 原型编码阶段: (5) 使用ADO.NET

删除ClerkList.aspx上面的所有控件,重头开始,按下面步骤先初始化控件:
拖入SqlDataSource控件,命名为dsDeptList
拖入DropDownList控件,命名为ddlDeptList
拖入SqlDataSource控件,命名为dsClerkListByDept
拖入GridViewt控件,命名为gvClerkListByDept
拖入SqlDataSource控件,命名为dsClerkDetail
拖入FormViewt控件,命名为fvClerkDetail
看控件的命名就应该知道各自负责什么功能了吧。
下面是设计模式的样式和前台源代码:
caroa_7.gif
None.gif      < form id = " form1 "  runat = " server " >
None.gif        
< strong > 请选择部门: </ strong >< asp:SqlDataSource ID = " dsDeptList "  runat = " server " ></ asp:SqlDataSource >
None.gif        
< asp:DropDownList ID = " ddlDeptList "  runat = " server " >
None.gif        
</ asp:DropDownList >< br  />
None.gif        
< br  />
None.gif        
< strong > 员工列表: </ strong >< br  />
None.gif        
< asp:SqlDataSource ID = " dsClerkListByDept "  runat = " server " ></ asp:SqlDataSource >
None.gif        
< asp:GridView ID = " gvClerkListByDept "  runat = " server " >
None.gif        
</ asp:GridView >
None.gif        
< br  />
None.gif        
< strong > 员工详细信息: </ strong >< br  />
None.gif        
< asp:SqlDataSource ID = " dsClerkDetail "  runat = " server " ></ asp:SqlDataSource >
None.gif        
< asp:FormView ID = " fvClerkDetail "  runat = " server " >
None.gif        
</ asp:FormView >
None.gif    
</ form >
够简洁吧,由于没有绑定数据源,也就没有缺省的那些自动生成的绑定字段了。

在设计界面什么都不要做,接下来编写相应的绑定代码,我们一步一步来,做一步看一下显示结果,前面的几步实现的效果跟以前做的绑定操作其实是一样的,只不过操作方式不一样,变成写后台代码了。
首先初始化部门列表数据源,并绑定到下拉框控件:
None.gif      protected   void  Page_Load( object  sender, EventArgs e)
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
//初始化部门数据源的连接字串和select命令
InBlock.gif
        dsDeptList.ConnectionString = WebConfigurationManager.ConnectionStrings["CAROAConnectionString"].ConnectionString;
InBlock.gif        dsDeptList.SelectCommand 
= "select Code_Dept.DeptID,Code_Dept.DeptName from Code_Dept";
InBlock.gif        
InBlock.gif
InBlock.gif        
//部门列表下拉框绑定数据源
InBlock.gif
        ddlDeptList.AutoPostBack = true;
InBlock.gif        
if (!IsPostBack)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            ddlDeptList.DataSourceID = dsDeptList.ID.ToString();
InBlock.gif            ddlDeptList.DataTextField = "DeptName";
InBlock.gif            ddlDeptList.DataValueField = "DeptID";

InBlock.gif            ddlDeptList.DataBind();
ExpandedSubBlockEnd.gif        }
ExpandedBlockEnd.gif    }
在这里,我们将下拉框设成了自动提交到服务器,同时设置了页面第一次访问才绑定数据源,而不是每次执行都绑定,这样就避免了下拉框中数据每次都会被重置。效果很好。

接着我们在page_load代码段中增加部门员工列表数据源和GridView控件的初始化和绑定,和上面不一样的是,数据源的select语句是带参的,而且参数是来源于部门下拉框中的值,利用拖放控件并设置数据源已经做过了,那么如何用代码来实现呢?
None.gif          // 初始化员工列表数据源
None.gif
        dsClerkListByDept.ConnectionString  =  WebConfigurationManager.ConnectionStrings[ " CAROAConnectionString " ].ConnectionString;
None.gif        dsClerkListByDept.SelectCommand 
=   " select ClerkID,RealName,JobNum from Clerk where Clerk.DeptID=@paraDeptID " ;
None.gif        
if  ( ! IsPostBack)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            
//这一行是指定参数@paraDeptID的来源是ControlParameter对象的一个实例
InBlock.gif
            dsClerkListByDept.SelectParameters.Add(new ControlParameter("paraDeptID""ddlDeptList""SelectedValue"));
ExpandedBlockEnd.gif        }

None.gif
None.gif        setgvClerkListByDeptField();
None.gif
None.gif        
// 员工列表绑定数据源
None.gif
        gvClerkListByDept.DataSourceID  =  dsClerkListByDept.ID.ToString();
None.gif        gvClerkListByDept.DataBind();

运行效果如下:
请选择部门: 公客部12市场部大客部

员工列表:
ClerkIDRealNameJobNum
3张大客3001
4李大客3002


现在市场部中无人员数据,我想实现返回记录为空的时候出现相应的提示信息,在代码中如何实现呢?
我觉得既然只要设置gridview的编辑模板EmptyDataTemplate就可以,为什么还要写代码?我又不太熟悉TemplateField的写法,为什么要去死钻牛角尖?
该省事的地方,该不需要花费精力的地方就不需要去研究如何写后台代码,用好ASP.NET2带给我们的便利就行了:
caroa_8.gif
前台aspx代码中只多了三行:
None.gif        <asp:GridView ID="gvClerkListByDept" runat="server">
None.gif            <EmptyDataTemplate>
None.gif                抱歉,该部门无返员工记录!
None.gif            </EmptyDataTemplate>

None.gif        </asp:GridView>

运行结果很不错,要是想编写一个定义ItemTemplate的代码:
None.gif      private   void  setgvClerkListByDeptField()
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        TemplateField myDataField 
= new TemplateField();
InBlock.gif        myDataField .ItemTemplate 
= new GridViewTemplate(DataControlRowType.DataRow, "ClerkName");
InBlock.gif
InBlock.gif        gvClerkListByDept.Columns.Add(myDataField );
ExpandedBlockEnd.gif    }

None.gif
None.gif    
public   class  GridViewTemplate : ITemplate
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
private DataControlRowType templateType;
InBlock.gif        
private string columnName;
InBlock.gif
InBlock.gif        
public GridViewTemplate(DataControlRowType type, string colname)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            templateType 
= type;
InBlock.gif            columnName 
= colname;
ExpandedSubBlockEnd.gif        }

InBlock.gif
InBlock.gif        
public void InstantiateIn(System.Web.UI.Control container)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
if (templateType == DataControlRowType.DataRow)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
//创建模板字段类型
InBlock.gif
InBlock.gif                
//指定模板字段的数据绑定
InBlock.gif
                switch (columnName)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    
case "":
InBlock.gif                        
break;
ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }
ExpandedSubBlockEnd.gif        }

InBlock.gif
ExpandedBlockEnd.gif    }
这么复杂,有必要吗?还有要是写一个自定义按钮字段或者其他什么字段的代码,倒还不如在设计窗口或者aspx文件的控件声明中直接去写呢。

不过,我想在员工列表中增加一个编辑按钮,而这个按钮名字虽然叫编辑,其实是选定,而且选定的操作是将详细信息FormView刷新。
突然发现我formview的template代码不会写,算了 还是先改用detailsview控件吧。再把员工弄熟了再看看能不能找到后台写formview的代码。
还有我想如果还没有选择一个员工就不出现员工详细信息的部分,所以我把页面中增加一个panel叫ClerkDetailPanel,将ClerkDetail的两个控件放进去。

员工详细信息的控件代码如下,代码中有一段为灰色的是因为接下来这一段要被移到子程序UpdateClerkDetail中去:
None.gif          // 初始化员工详细信息数据源
None.gif
        dsClerkDetail.ConnectionString  =  WebConfigurationManager.ConnectionStrings[ " CAROAConnectionString " ].ConnectionString;
None.gif        dsClerkDetail.SelectCommand 
=   " select ClerkID,RealName,JobNum,DeptID from Clerk where Clerk.ClerkID=@paraClerkID " ;
None.gif        
if  ( ! this .IsPostBack)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            
//这一行是指定参数@paraClerkID的来源是ControlParameter对象的一个实例
InBlock.gif
            dsClerkDetail.SelectParameters.Add(new ControlParameter("paraClerkID""gvClerkListByDept""SelectedValue"));
ExpandedBlockEnd.gif        }

为了给员工列表GridView增加一个选择按钮,我们使用前台编辑列的方式增加一个选择按钮并且增加OnSelectedIndexChanged的事件代码如下:
None.gif      protected   void  gvClerkListByDept_SelectedIndexChanged( object  sender, EventArgs e)
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        ClerkDetailPanel.Visible 
= true;
InBlock.gif        UpdateClerkDetail();
ExpandedBlockEnd.gif    }

更新员工详细信息的程序如下,其实就是执行了一下数据绑定:
None.gif      private   void  UpdateClerkDetail()
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        dvClerkDetail.DataSourceID 
= dsClerkDetail.ID.ToString();
InBlock.gif        dvClerkDetail.DataBind();
ExpandedBlockEnd.gif    }

不得不提的是,在改变部门后,由于员工列表的SelectIndex并未改变,所以不会触发员工详细信息的更新,这是一个bug,解决代码如下:
None.gif      protected   void  ddlDeptList_SelectedIndexChanged( object  sender, EventArgs e)
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        gvClerkListByDept.SelectedIndex 
= -1;
InBlock.gif        ClerkDetailPanel.Visible 
= false;
ExpandedBlockEnd.gif    }

执行结果还是比较满意的:
请选择部门: 公客部12市场部大客部

员工列表:
 ClerkIDRealNameJobNum
3张大客3001
4李大客3002
5Shao大客3003
 

员工详细信息:
 
ClerkID4
RealName李大客
JobNum3002
DeptID3
要给员工详细信息加上编辑,删除操作。就用到DetailsView的相关属性和事件。更详细的代码编写见下一篇。
首先,DetailsView的字段和GridView是一样的7种类型:BoundedField,ButtonField,CommandField,CheckBoxField,HyperLinkField,ImageField,TemplateField,不过前台的语法声明有点不同,字段DetailsView是用<Fields>,而GridView是Columns。

其实上面实现的后台代码方式还不是正宗ADO.NET方式,我觉得用SqlDataAdapter执行conn+SQLCommand_String 然后再Fill给DataSet,这样DataSet将被填充数据表以及之间的关系,再将DataSet中的对应DataTable赋给某个控件,如gridview,detailsview等。 才是ADO.NET的写法。这样可以把离线的DataSet放到session中,从而通过控件的RowFilter属性可以让不同控件操作显示同一个DataView,速度快,省资源。有必要才需要连接数据库更新DataView或者更新数据库。

转载于:https://www.cnblogs.com/hulu/archive/2007/07/05/806920.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值