大数据之路

博客园 首页 新随笔 联系 订阅 管理

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);
    }

  }
 }
}

posted on 2006-08-03 11:54  小潘  阅读(402)  评论(0)    收藏  举报