Asp.net中DataGrid利用DataRelation显示主从表信息(可控制从表信息隐藏和显示).(DataGrid 嵌套)...

本文分享了一个入门级程序,开发环境为asp.net 1.1.4322.2032,使用Visual Studio 2003和Window Server 2003,数据库为SqlServer 2000。程序功能包括利用DataRelation在DataGrid显示主从表信息、支持分页及主从表增删改等,还给出了具体代码和参考链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是我这个菜鸟做的入门级的程序,与菜鸟们一起分享~~~~~基本效果图:


主页面效果图
(程序主页面图(子表的信息可显示和隐藏))

子页面(修改页面)
(showModalDialog弹出的修改子窗口,可根据情况刷新父窗口)


一.开发环境:
.net 版本:asp.net 1.1.4322.2032
工具:Visual Studio 2003
操作系统:Window Server 2003
数据库:SqlServer 2000

二.程序功能:

1.利用DataRelation在DataGrid中显示主从表信息,从表的信息可以显示/隐藏.

2.支持分页(系统默认分页),支持主表和从表的增加/更新/删除.

3.简要需求说明:
(1)班次(EPM_WorkTime表和班次的值班区间(EPM_WorkTimeChild表之间是一对多的关系.(也许这里没必要这样麻烦,但为了学习,所以如此做了.)

 CREATE TABLE [EPM_WorkTimeChild] (
  [id] [int] IDENTITY (1, 1) NOT NULL ,
  [parentid] [int] NOT NULL ,
  [timestart] [varchar] (20) COLLATE Chinese_PRC_CI_AS NULL ,
  [timeend] [varchar] (20) COLLATE Chinese_PRC_CI_AS NULL ,
  CONSTRAINT [PK_EPM_WorkTimeChild] PRIMARY KEY  CLUSTERED
  (
   [id]
  )  ON [PRIMARY]
 ) ON [PRIMARY]
 GO


 CREATE TABLE [EPM_WorkTime] (
  [id] [int] IDENTITY (1, 1) NOT NULL ,
  [name] [varchar] (100) COLLATE Chinese_PRC_CI_AS NULL
  CONSTRAINT [PK_EPM_WorkTime] PRIMARY KEY  CLUSTERED
  (
   [id]
  )  ON [PRIMARY]
 ) ON [PRIMARY]
 GO

 

(2)从表中使用了ViewState{"Id"]来保存Request.QueryString方式传递过来的parentid;因为多处用到它,所以使用了ViewStae而不是每次Request.ueryString来获得,不知这里是否合适.cry_smile.gif

(3)其中的一些JS脚本可以通过注册的方式后台添加,这里没有这样,大都写在ASPX文件中了.
   数据库访问没有使用Enterprise Library 等比较好的数据访问封装,对这些不太熟悉.而是拼凑了别人的数据访问类.
(4)子窗口中若选择了确定,则返回后刷新父窗口(因为内容更新了),若选择取消则不刷新父窗口.
(5)关键是下面的一行代码,比葫芦画瓢能用了,但不理解.11.gif07.gif

ExpandedBlockStart.gif ContractedBlock.gif DataSource=' <% dot.gif # ((System.Data.DataRowView)(Container.DataItem)).CreateChildView("WorkTime" %> '


三.具体程序代码:
WorkTimeManage.aspx:

 1 ExpandedBlockStart.gif ContractedBlock.gif <% dot.gif @ Page language="c#" Codebehind="WorkTimeManage.aspx.cs" AutoEventWireup="false" Inherits="EPNew.WorkTimeManage"  SmartNavigation ="true" %>
 2 None.gif <! DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"  >
 3 None.gif < HTML >
 4 None.gif     < HEAD >
 5 None.gif         < title > WorkTimeManage </ title >
 6 None.gif         < meta  content ="Microsoft Visual Studio .NET 7.1"  name ="GENERATOR" >
 7 None.gif         < meta  content ="C#"  name ="CODE_LANGUAGE" >
 8 None.gif         < meta  content ="JavaScript"  name ="vs_defaultClientScript" >
 9 None.gif         < meta  content ="http://schemas.microsoft.com/intellisense/ie5"  name ="vs_targetSchema" >
10 ExpandedBlockStart.gifContractedBlock.gif         < SCRIPT  language ="JavaScript" > dot.gif
11InBlock.gif            <!--
12InBlock.gif            //展开和关闭时候显示/隐藏子表信息
13InBlock.gif            function showDiv(img,div)
14ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
15InBlock.gif                var img = document.getElementById(img);
16InBlock.gif                var div = document.getElementById(div);
17InBlock.gif                var picName = img.src;
18InBlock.gif                picName = picName.substring(picName.lastIndexOf("/")+1);
19InBlock.gif                if (picName.toLowerCase() == "close.gif")
20ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
21InBlock.gif                    div.style.display ="block";
22InBlock.gif                    img.src = "images/open.gif";
23ExpandedSubBlockEnd.gif                }

24InBlock.gif                else
25ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
26InBlock.gif                    div.style.display ="none";
27InBlock.gif                    img.src = "images/close.gif";
28ExpandedSubBlockEnd.gif                }

29ExpandedSubBlockEnd.gif            }

30InBlock.gif            
31InBlock.gif            
32InBlock.gif            //-->
33ExpandedBlockEnd.gif        
</ SCRIPT >
34 None.gif     </ HEAD >
35 None.gif     < body  MS_POSITIONING ="FlowLayout" >
36 None.gif         < form  id ="Form1"  method ="post"  runat ="server" >
37 None.gif             < TABLE  id ="Table1"  cellSpacing ="1"  cellPadding ="1"  width ="100%"  border ="0" >
38 None.gif                 < TR  class ="Title" >
39 None.gif                     < TD  align ="center" > 班次列表 </ TD >
40 None.gif                 </ TR >
41 None.gif                 < TR  class ="Title" >
42 None.gif                     < TD  align ="left" > &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  值班班次名称: &nbsp;
43 None.gif                         < asp:textbox  id ="TxtName"  runat ="server" ></ asp:textbox > &nbsp;
44 None.gif                         < asp:button  id ="BtnAdd"  runat ="server"  Text ="增加值班班次" ></ asp:button ></ TD >
45 None.gif                 </ TR >
46 None.gif                 < TR >
47 None.gif                     < TD >< asp:datagrid  id ="DataGrid1"  runat ="server"  DataKeyField ="id"  Width ="100%"  AutoGenerateColumns ="False"
48 None.gif                            ShowHeader ="False"  BackColor ="#fffff6"  AllowPaging ="True"  PageSize ="3" >
49 None.gif                             < Columns >
50 None.gif                                 < asp:TemplateColumn >
51 None.gif                                     < ItemTemplate >
52 None.gif                                         < TABLE  border ="0"  width ="100%" >
53 None.gif                                             < TR >
54 None.gif                                                 < TD  width ="70" >
55 None.gif                                                     < asp:Label  ID ="LblId"  Runat ="server"  Visible ="False"  text ='<%#  DataBinder.Eval(Container.DataItem,"id")% > '>
56 None.gif                                                     </ asp:Label >
57 None.gif                                                     &nbsp;&nbsp;
58 None.gif                                                     < asp:Image  ID ="ImgOpen"  Runat ="server"  open ="true"  style ="cursor:hand"  ImageUrl ="images/close.gif" ></ asp:Image ></ TD >
59 None.gif                                                 < td >
60 None.gif                                                     < asp:Label  ID  ="LblName"  Runat ="server"  Text  ='<%#  DataBinder.Eval(Container.DataItem,"Name")% > '>
61 None.gif                                                     </ asp:Label >
62 None.gif                                                 </ td >
63 None.gif                                                 < td  width ="150" >
64 None.gif                                                     < asp:LinkButton  ID ="LbtnEdit"  Runat ="server"  Text ="修改" ></ asp:LinkButton >
65 None.gif                                                     &nbsp;&nbsp;
66 None.gif                                                     < asp:LinkButton  ID ="LbtnDel"  Runat ="server"  Text ="删除"  CommandName ="Delete" ></ asp:LinkButton >
67 None.gif                                                 </ td >
68 None.gif                                             </ TR >
69 None.gif                                             < TR >
70 None.gif                                                 < TD  colspan ="3"  align ="center"  bgcolor ="#fefefe" >
71 None.gif                                                     < asp:Panel  ID ="PnlContent"  Runat ="server"  style ="display:none"  Border ="0" >
72 None.gif                                                         < asp:DataGrid  ID ="DgContent"  Runat ="server"  Width ="80%"  DataKeyField ="id"  AutoGenerateColumns = "False"  BorderColor ="#3677B1"  BackColor ="#fefefe"  
73 None.gif                                                        DataSource ='<%#  ((System.Data.DataRowView)(Container.DataItem)).CreateChildView("WorkTime") % > '>
74 None.gif                                                             < Columns >
75 None.gif                                                                 < asp:BoundColumn  DataField ="id"  HeaderText ="序号"  HeaderStyle-HorizontalAlign ="Center" ></ asp:BoundColumn >
76 None.gif                                                                 < asp:BoundColumn  DataField ="TimeStart"  HeaderText ="开始时间"  HeaderStyle-HorizontalAlign ="Center" ></ asp:BoundColumn >
77 None.gif                                                                 < asp:BoundColumn  DataField ="TimeEnd"  HeaderText ="结束时间"  HeaderStyle-HorizontalAlign ="Center" ></ asp:BoundColumn >
78 None.gif                                                             </ Columns >
79 None.gif                                                         </ asp:DataGrid >
80 None.gif                                                     </ asp:Panel >
81 None.gif                                                 </ TD >
82 None.gif                                             </ TR >
83 None.gif                                         </ TABLE >
84 None.gif                                     </ ItemTemplate >
85 None.gif                                 </ asp:TemplateColumn >
86 None.gif                             </ Columns >
87 None.gif                             < PagerStyle  Mode ="NumericPages" ></ PagerStyle >
88 None.gif                         </ asp:datagrid ></ TD >
89 None.gif                 </ TR >
90 None.gif                 < TR >
91 None.gif                     < TD ></ TD >
92 None.gif                 </ TR >
93 None.gif             </ TABLE >
94 None.gif         </ form >
95 None.gif     </ body >
96 None.gif </ HTML >
97 None.gif


WorkTimeManage.aspx.cs

  1 None.gif using  System;
  2 None.gif using  System.Collections;
  3 None.gif using  System.ComponentModel;
  4 None.gif using  System.Data;
  5 None.gif using  System.Data.SqlClient;
  6 None.gif using  System.Drawing;
  7 None.gif using  System.Web;
  8 None.gif using  System.Web.SessionState;
  9 None.gif using  System.Web.UI;
 10 None.gif using  System.Web.UI.WebControls;
 11 None.gif using  System.Web.UI.HtmlControls;
 12 None.gif
 13 None.gif namespace  EPNew
 14 ExpandedBlockStart.gifContractedBlock.gif dot.gif {
 15ExpandedSubBlockStart.gifContractedSubBlock.gif    /**//// <summary>
 16InBlock.gif    /// WorkTimeManage 的摘要说明。
 17ExpandedSubBlockEnd.gif    /// </summary>

 18InBlock.gif    public class WorkTimeManage : System.Web.UI.Page
 19ExpandedSubBlockStart.gifContractedSubBlock.gif    dot.gif{
 20InBlock.gif        protected System.Web.UI.WebControls.DataGrid DataGrid1;
 21InBlock.gif        protected System.Web.UI.WebControls.TextBox TxtName;
 22InBlock.gif        protected System.Web.UI.WebControls.Button BtnAdd;
 23InBlock.gif        
 24InBlock.gif        //数据访问实例
 25InBlock.gif        protected ClassConn connE = new ClassConn();
 26InBlock.gif
 27InBlock.gif        private void Page_Load(object sender, System.EventArgs e)
 28ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 29InBlock.gif            // 在此处放置用户代码以初始化页面
 30InBlock.gif            if(!IsPostBack)
 31ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 32InBlock.gif                //绑定数据
 33InBlock.gif                InitData();
 34ExpandedSubBlockEnd.gif            }

 35ExpandedSubBlockEnd.gif        }

 36InBlock.gif        
 37ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
 38InBlock.gif        /// 初始化数据
 39ExpandedSubBlockEnd.gif        /// </summary>

 40InBlock.gif        private void InitData()
 41ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 42InBlock.gif            string strSql = "select id,name from  EPM_WorkTime  order by id ;select * from EPM_WorkTimeChild ";
 43InBlock.gif            DataSet ds = connE.getDs(strSql);
 44InBlock.gif            ds.Tables[0].TableName = "farther";
 45InBlock.gif            ds.Tables[1].TableName = "child";
 46InBlock.gif            DataColumn dcFarther = ds.Tables["farther"].Columns["id"];
 47InBlock.gif            DataColumn dcChild = ds.Tables["child"].Columns["parentid"];
 48InBlock.gif            //主从表的关联
 49InBlock.gif            DataRelation dRelation = new DataRelation("WorkTime",dcFarther,dcChild,true);
 50InBlock.gif            ds.Relations.Add(dRelation);
 51InBlock.gif            DataGrid1.DataSource = ds.Tables["farther"].DefaultView;
 52InBlock.gif            DataGrid1.DataBind();
 53InBlock.gif
 54ExpandedSubBlockEnd.gif        }

 55ContractedSubBlock.gifExpandedSubBlockStart.gif        Web 窗体设计器生成的代码#region Web 窗体设计器生成的代码
 56InBlock.gif        override protected void OnInit(EventArgs e)
 57ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 58InBlock.gif            //
 59InBlock.gif            // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
 60InBlock.gif            //
 61InBlock.gif            InitializeComponent();
 62InBlock.gif            base.OnInit(e);
 63ExpandedSubBlockEnd.gif        }

 64InBlock.gif        
 65ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
 66InBlock.gif        /// 设计器支持所需的方法 - 不要使用代码编辑器修改
 67InBlock.gif        /// 此方法的内容。
 68ExpandedSubBlockEnd.gif        /// </summary>

 69InBlock.gif        private void InitializeComponent()
 70ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{    
 71InBlock.gif            this.BtnAdd.Click += new System.EventHandler(this.BtnAdd_Click);
 72InBlock.gif            this.DataGrid1.PageIndexChanged += new System.Web.UI.WebControls.DataGridPageChangedEventHandler(this.DataGrid1_PageIndexChanged);
 73InBlock.gif            this.DataGrid1.DeleteCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.DataGrid1_DeleteCommand);
 74InBlock.gif            this.DataGrid1.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler(this.DataGrid1_ItemDataBound);
 75InBlock.gif            this.Load += new System.EventHandler(this.Page_Load);
 76InBlock.gif
 77ExpandedSubBlockEnd.gif        }

 78ExpandedSubBlockEnd.gif        #endregion

 79InBlock.gif
 80InBlock.gif
 81ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
 82InBlock.gif        /// 设置修改按钮打开窗口的JS事件
 83InBlock.gif        /// 设置展开图片的JS事件.
 84InBlock.gif        /// 设置删除确认的JS事件
 85InBlock.gif        /// </summary>
 86InBlock.gif        /// <param name="sender"></param>
 87ExpandedSubBlockEnd.gif        /// <param name="e"></param>

 88InBlock.gif        private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
 89ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 90InBlock.gif            Label lblName = (Label) e.Item.FindControl("LblName");
 91InBlock.gif            LinkButton  lbtn = (LinkButton) e.Item.FindControl("LbtnEdit");
 92InBlock.gif            Label lbl = (Label) (e.Item.FindControl("LblId"));
 93InBlock.gif            System.Web.UI.WebControls.Image img  = (System.Web.UI.WebControls.Image)(e.Item.FindControl("ImgOpen"));
 94InBlock.gif            Panel pnl = (Panel)(e.Item.FindControl("PnlContent"));
 95InBlock.gif            LinkButton lbtnDel = (LinkButton) (e.Item.FindControl("LbtnDel"));
 96InBlock.gif            if(img != null  && pnl != null && lbtn != null && lbl!= null && lbtnDel != null && lblName != null)
 97ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 98InBlock.gif                //修改按钮打开窗口的js事件
 99InBlock.gif                lbtn.Attributes.Add("onclick","var obj = showModalDialog(\"WorkTimeChildManage.aspx?id="+lbl.Text+"&name="
100InBlock.gif                        +Server.UrlEncode(lblName.Text)+"\",\"workchild\",\"dialogWidth:500px; dialogHeight:500px;help:0;"
101InBlock.gif                        +"status:0;resizeable:1\");if(obj==\"true\") location.reload(); else  return false;");
102InBlock.gif                //lbtn.Attributes.Add("onclick","var obj = window.open(\"EmployeeSetPower.aspx?id="+strId+"\");if(obj==false) return false;");
103InBlock.gif                //展开图片的JS事件.
104InBlock.gif                img.Attributes.Add("onclick","showDiv('"+img.ClientID+"','"+pnl.ClientID+"');return false;");
105InBlock.gif                //删除确认
106InBlock.gif                lbtnDel.Attributes.Add("onclick","return confirm('该班次的所有值班区间也将删除,确实要删除?');");
107ExpandedSubBlockEnd.gif            }

108InBlock.gif
109ExpandedSubBlockEnd.gif        }

110InBlock.gif        
111ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
112InBlock.gif        /// 页码更改事件
113InBlock.gif        /// </summary>
114InBlock.gif        /// <param name="source"></param>
115ExpandedSubBlockEnd.gif        /// <param name="e"></param>

116InBlock.gif        private void DataGrid1_PageIndexChanged(object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
117ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
118InBlock.gif            DataGrid1.CurrentPageIndex = e.NewPageIndex;
119InBlock.gif            //绑定数据
120InBlock.gif            InitData();
121ExpandedSubBlockEnd.gif        }

122InBlock.gif        
123ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
124InBlock.gif        /// 删除值班班次,同时删除两个表的记录(EPM_WorkTime和EPM_WorkTimeChild).
125InBlock.gif        /// </summary>
126InBlock.gif        /// <param name="source"></param>
127ExpandedSubBlockEnd.gif        /// <param name="e"></param>

128InBlock.gif        private void DataGrid1_DeleteCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
129ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
130InBlock.gif            //程序级事务删除
131InBlock.gif            string strId = DataGrid1.DataKeys[e.Item.ItemIndex].ToString();
132InBlock.gif            connE.Open();
133InBlock.gif            SqlTransaction trans = connE.conn.BeginTransaction();
134InBlock.gif            SqlCommand cmd = new SqlCommand();
135InBlock.gif            cmd.Connection = connE.conn;
136InBlock.gif            cmd.Transaction = trans;
137InBlock.gif            try
138ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
139InBlock.gif                cmd.CommandText= "delete from EPM_WorkTimeChild where parentid ="+strId;
140InBlock.gif                cmd.ExecuteNonQuery();
141InBlock.gif                cmd.CommandText = "delete from EPM_WorkTime where id ="+strId;
142InBlock.gif                cmd.ExecuteNonQuery();
143InBlock.gif                trans.Commit();
144ExpandedSubBlockEnd.gif            }

145InBlock.gif            catch(SqlException Ex1)
146ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
147InBlock.gif                trans.Rollback();
148InBlock.gif                Response.Write(Ex1.ToString());
149InBlock.gif                
150ExpandedSubBlockEnd.gif            }

151InBlock.gif            finally
152ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
153InBlock.gif                trans.Dispose();
154InBlock.gif                connE.Close();
155ExpandedSubBlockEnd.gif            }

156InBlock.gif            //为了防止某页数据只剩一条记录删除后发生的错误,要判断当前页的记录数和当前页码
157InBlock.gif            if(DataGrid1.Items.Count ==1 && DataGrid1.CurrentPageIndex>0)
158ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
159InBlock.gif                DataGrid1.CurrentPageIndex --;
160ExpandedSubBlockEnd.gif            }

161InBlock.gif            //重新绑定数据
162InBlock.gif            InitData();
163ExpandedSubBlockEnd.gif        }

164InBlock.gif        
165ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
166InBlock.gif        /// 增加一值班班次
167InBlock.gif        /// </summary>
168InBlock.gif        /// <param name="sender"></param>
169ExpandedSubBlockEnd.gif        /// <param name="e"></param>

170InBlock.gif        private void BtnAdd_Click(object sender, System.EventArgs e)
171ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
172InBlock.gif            connE.builder("select top 1 * from EPM_WorkTime");
173InBlock.gif            connE.dr["name"= this.TxtName.Text.Trim();
174InBlock.gif            connE.builderClose();
175InBlock.gif            DataGrid1.CurrentPageIndex = 0;
176InBlock.gif            //重新绑定数据
177InBlock.gif            InitData();
178ExpandedSubBlockEnd.gif        }

179ExpandedSubBlockEnd.gif    }

180ExpandedBlockEnd.gif}

181 None.gif


四.备注:
本文参考了:
利用ASP.NET DataGrid显示主次关系的数据
http://dotnet.aspx.cc/ShowDetail.aspx?id=149E5DD7-3B32-461e-ACC6-51D1652E6746

转载于:https://www.cnblogs.com/adandelion/archive/2005/11/12/274505.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值