using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
namespace DateCollection
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.DataGrid DGridParent;
protected System.Web.UI.WebControls.DataGrid DGridChild;
protected System.Web.UI.WebControls.Button btnAddData;
protected System.Web.UI.WebControls.Button btnAddConstration;
protected System.Web.UI.WebControls.Button btnAddForeign;
protected System.Web.UI.WebControls.Button btnUpdate;
protected System.Web.UI.WebControls.Button btnRl;
protected System.Web.UI.WebControls.TextBox TextBox1;
protected System.Web.UI.WebControls.DropDownList DropDownList1;
protected System.Web.UI.WebControls.Button btnCreatDateSet;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.btnCreatDateSet.Click += new System.EventHandler(this.btnCreatDateSet_Click);
this.DGridChild.SelectedIndexChanged += new System.EventHandler(this.DGridChild_SelectedIndexChanged);
this.btnAddData.Click += new System.EventHandler(this.btnAddData_Click);
this.btnAddConstration.Click += new System.EventHandler(this.btnAddConstration_Click);
this.btnAddForeign.Click += new System.EventHandler(this.btnAddForeign_Click);
this.btnUpdate.Click += new System.EventHandler(this.btnUpdate_Click);
this.btnRl.Click += new System.EventHandler(this.btnRl_Click);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
/// <summary>
/// 创建数据集
/// </summary>
public void CreateDateSet()
{
DataSet ds=new DataSet("NyDataSet");//创建数据集
DataTable dtp=new DataTable("parent");//创建要加到数据集的两个数据表
DataTable dtc=new DataTable("child");
ds.Tables.Add(dtp);
ds.Tables.Add(dtc);
Session["dss"]=ds;//把数据集保留到session中防止消失
}
/// <summary>
/// 创建数据表
/// </summary>
public void createtable()
{
DataSet ds=(DataSet)Session["dss"];//对原来创建的数据集中的表进行定义
ds.Tables["parent"].Columns.Add("parentid",typeof(int));
ds.Tables["parent"].Columns.Add("parentname",typeof(string));
ds.Tables["child"].Columns.Add("childid",typeof(int));
ds.Tables["child"].Columns.Add("childname",typeof(string));
ds.Tables["child"].Columns.Add("parentid",typeof(int));
//修改表头
ds.Tables["parent"].Columns["parentid"].Caption="主键";
ds.Tables["child"].Columns["childid"].Caption="主键";
Session["dss"]=ds;
DataBind2();
}
/// <summary>
/// 为两个表添加数据
/// </summary>
public void addTableData()
{
try
{
DataSet ds=(DataSet)Session["dss"];
//为parent表添加两行
DataRow dr=ds.Tables["parent"].NewRow();//注意是为parent表添加数据而不是new。。
dr["parentid"]=1;
dr["parentname"]="张三";
ds.Tables["parent"].Rows.Add(dr);
DataRow dr2=ds.Tables["parent"].NewRow();//注意是为parent表添加数据而不是new。。
dr2["parentid"]=2;
dr2["parentname"]="李四";
ds.Tables["parent"].Rows.Add(dr2);
//为child表添加两行数据
DataRow drc=ds.Tables["child"].NewRow();
drc["childid"]=0;
drc["childname"]="小明";
drc["parentid"]=1;
ds.Tables["child"].Rows.Add(drc);
DataRow drc2=ds.Tables["child"].NewRow();
drc2["childid"]=1;
drc2["childname"]="小刚";
drc2["parentid"]=2;
ds.Tables["child"].Rows.Add(drc2);
Session["dss"]=ds;
DataBind2();
}
catch(Exception er)
{
Response.Write(er.Message);
}
}
/// <summary>
/// 为两个表添加唯一约束
/// </summary>
public void addUniqueConstraint()
{
DataSet ds=(DataSet)Session["dss"];
System.Data.UniqueConstraint ucparent=new UniqueConstraint("uniparent",ds.Tables["parent"].Columns["parentid"]);
ds.Tables["parent"].Constraints.Add(ucparent);
System.Data.UniqueConstraint ucchild=new UniqueConstraint("unichild",ds.Tables["child"].Columns["childid"]);
ds.Tables["child"].Constraints.Add(ucchild);
Session["dss"]=ds;
Response.Write("<script langiage='javascript'>alert('添加唯一约束成功')</script>");
}
/// <summary>
/// 为两个表添加外键
/// </summary>
public void addForeignKey()
{
DataSet ds=(DataSet)Session["dss"];
System.Data.ForeignKeyConstraint fc=new ForeignKeyConstraint("fc",ds.Tables["parent"].Columns["parentid"],ds.Tables["child"].Columns["parentid"]);
ds.Tables["child"].Constraints.Add(fc);
Session["dss"]=ds;
Response.Write("<script langiage='javascript'>alert('添加外键约束成功')</script>");
}
/// <summary>
/// 创建两个表的关系根据父表的项可得到相对应的子表的对应相
/// </summary>
public void createRealation()
{
DataSet ds=(DataSet)Session["dss"];
ds.Relations.Add("newrl",ds.Tables["parent"].Columns["parentid"],ds.Tables["child"].Columns["parentid"]);
Session["dss"]=ds;
}
public void DataBind2()
{
DataSet dtbind=(DataSet)Session["dss"];
this.DGridParent.DataSource=dtbind.Tables["parent"].DefaultView;
this.DGridChild.DataSource=dtbind.Tables["child"].DefaultView;
this.DataBind();
}
private void DGridChild_SelectedIndexChanged(object sender, System.EventArgs e)
{
}
private void btnCreatDateSet_Click(object sender, System.EventArgs e)
{
try
{
CreateDateSet();
createtable();
DataBind2();
}
catch(Exception er)
{
Response.Write(er.Message);
}
}
private void btnAddData_Click(object sender, System.EventArgs e)
{
addTableData();
}
private void btnAddConstration_Click(object sender, System.EventArgs e)
{
addUniqueConstraint();
}
private void btnAddForeign_Click(object sender, System.EventArgs e)
{
addForeignKey();
}
/// <summary>
/// 更新数据
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnUpdate_Click(object sender, System.EventArgs e)
{ Random rd=new Random();
DataSet ds=(DataSet)Session["dss"];
ds.Tables["parent"].Rows[0][0]=rd.NextDouble()*1000/10;
DataBind2();
Response.Write("<script langiage='javascript'>alert('数据更新成功')</script>");
}
private void btnRl_Click(object sender, System.EventArgs e)
{
createRealation();
try
{
DataSet ds=(DataSet)Session["dss"];
System.Data.DataRow dr=ds.Tables["parent"].Rows[1];
System.Data.DataRow[] s=dr.GetChildRows(ds.Relations["newrl"]);
foreach(System.Data.DataRow drr in s )
{
this.DropDownList1.Items.Add(drr[0].ToString());
}
// this.TextBox1.Text=s;
}
catch(Exception er)
{
Response.Write(er.Message);
}
}
}
}
浙公网安备 33010602011771号