DataRelation(DataSet中父子表)的一个示例
来源:互联网 发布:树莓派3 ubuntu 编辑:程序博客网 时间:2024/05/18 13:24
System.Data.DataRelation 类,表示两个 DataTable 对象之间的父/子关系。在常见的查询中,可以利用sql2005/2008的CTE应用来进行递归查询,
这里有一个典型示例:http://www.cnblogs.com/downmoon/archive/2009/10/23/1588405.html
此外,在数据量不大的情况下,也可以用DataRelation进行主子表或父子表的关联,参看下例:
假定:有两张表请假类型LeaveType和请假表Leave
这里是一个表结构的SQL:
代码
create table LeaveType (
PKID int identity(1,1),
TypeName nvarchar(50) null,
CurState smallint not null default 0,
constraint PK_LEAVETYPE primary key (PKID)
)
go
create table Leave (
PKID int identity(1,1),
Title nvarchar(50) null,
Reason nvarchar(254) null,
LoginID nvarchar(50) null,
LeaveTypeID int ,
DepartID int null,
EmployeeID int null,
AddTime datetime null,
BeginTime datetime null,
EndTime datetime null,
TBeginDate datetime null,
TEndDate datetime null,
Remark nvarchar(1000) null,
ModUser nvarchar(50) null,
ModTime datetime null,
CurState smallint not null default 0,
constraint PK_LEAVE primary key (PKID)
)
go
PKID int identity(1,1),
TypeName nvarchar(50) null,
CurState smallint not null default 0,
constraint PK_LEAVETYPE primary key (PKID)
)
go
create table Leave (
PKID int identity(1,1),
Title nvarchar(50) null,
Reason nvarchar(254) null,
LoginID nvarchar(50) null,
LeaveTypeID int ,
DepartID int null,
EmployeeID int null,
AddTime datetime null,
BeginTime datetime null,
EndTime datetime null,
TBeginDate datetime null,
TEndDate datetime null,
Remark nvarchar(1000) null,
ModUser nvarchar(50) null,
ModTime datetime null,
CurState smallint not null default 0,
constraint PK_LEAVE primary key (PKID)
)
go
再插入一些测试数据:
truncate table LeaveType
insert into
LeaveType
select '事假',1 union all
Select '病假',1 union all
select '婚假',1 union all
select '产假',1 union all
select '特休假',1
go
Insert into Leave
select '请假'+Convert( Nvarchar(11),dateadd(dd,-500,getdate()),120),'准备与方鸿渐结婚','孙嘉柔',3,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
union all
select '回娘家'+Convert( Nvarchar(11),dateadd(dd,-200,getdate()),120),'准备为方鸿渐生孩子','孙嘉柔',4,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
union all
select
'回娘家'+Convert( Nvarchar(11),dateadd(dd,-10,getdate()),120),'准备与方鸿渐离婚','孙嘉柔',1,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
union all
select '回娘家'+Convert( Nvarchar(11),dateadd(dd,-2,getdate()),120),'准备与方鸿渐离婚','孙嘉柔',2,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
union all
select '回娘家'+Convert( Nvarchar(11),getdate(),120),'准备与方鸿渐离婚','孙嘉柔',2,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
update Leave set Title='第'+cast(PKID as nvarchar(10))+'次'+Title
insert into
LeaveType
select '事假',1 union all
Select '病假',1 union all
select '婚假',1 union all
select '产假',1 union all
select '特休假',1
go
Insert into Leave
select '请假'+Convert( Nvarchar(11),dateadd(dd,-500,getdate()),120),'准备与方鸿渐结婚','孙嘉柔',3,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
union all
select '回娘家'+Convert( Nvarchar(11),dateadd(dd,-200,getdate()),120),'准备为方鸿渐生孩子','孙嘉柔',4,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
union all
select
'回娘家'+Convert( Nvarchar(11),dateadd(dd,-10,getdate()),120),'准备与方鸿渐离婚','孙嘉柔',1,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
union all
select '回娘家'+Convert( Nvarchar(11),dateadd(dd,-2,getdate()),120),'准备与方鸿渐离婚','孙嘉柔',2,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
union all
select '回娘家'+Convert( Nvarchar(11),getdate(),120),'准备与方鸿渐离婚','孙嘉柔',2,1,1909,getdate(),'2010-1-1','2012-1-1','2010-1-1','2012-1-1',
'这回铁了心了','孙嘉柔',getdate(),1
update Leave set Title='第'+cast(PKID as nvarchar(10))+'次'+Title
查询主要代码如下:
protected void Page_Load(object sender, EventArgs e)
{
SqlConnection objConn = default(SqlConnection);
SqlDataAdapter da = default(SqlDataAdapter);
DataSet ds = default(DataSet);
//DataRow dtrParent = default(DataRow);
//DataRow dtrChild = default(DataRow);
objConn = new SqlConnection(System.Configuration.ConfigurationManager.AppSettings["Testdb"]);
da = new SqlDataAdapter("SELECT * FROM LeaveType", objConn);
ds = new DataSet();
try
{
objConn.Open();
da.Fill(ds, "LeaveTypes");
da.SelectCommand = new SqlCommand("SELECT * FROM Leave", objConn);
da.Fill(ds, "Leaves");
}
catch (SqlException exc)
{
Response.Write(exc.ToString());
}
finally
{
objConn.Dispose();
}
////Create the Data Relationship
ds.Relations.Add("Type_Leave", ds.Tables["LeaveTypes"].Columns["PKID"], ds.Tables["Leaves"].Columns["LeaveTypeID"]);
////Display the Category and Child Products Within
foreach (DataRow drParent in ds.Tables["LeaveTypes"].Rows)
{
lblDisplay.Text += "<h3>" + drParent["TypeName"] + "</h3><ul>";
foreach (DataRow drChild in drParent.GetChildRows("Type_Leave"))
{
lblDisplay.Text += "<li>" + drChild["loginID"] + drChild["Title"] + drChild["Reason"] + "</li>";
}
lblDisplay.Text += "</ul>";
}
}
{
SqlConnection objConn = default(SqlConnection);
SqlDataAdapter da = default(SqlDataAdapter);
DataSet ds = default(DataSet);
//DataRow dtrParent = default(DataRow);
//DataRow dtrChild = default(DataRow);
objConn = new SqlConnection(System.Configuration.ConfigurationManager.AppSettings["Testdb"]);
da = new SqlDataAdapter("SELECT * FROM LeaveType", objConn);
ds = new DataSet();
try
{
objConn.Open();
da.Fill(ds, "LeaveTypes");
da.SelectCommand = new SqlCommand("SELECT * FROM Leave", objConn);
da.Fill(ds, "Leaves");
}
catch (SqlException exc)
{
Response.Write(exc.ToString());
}
finally
{
objConn.Dispose();
}
////Create the Data Relationship
ds.Relations.Add("Type_Leave", ds.Tables["LeaveTypes"].Columns["PKID"], ds.Tables["Leaves"].Columns["LeaveTypeID"]);
////Display the Category and Child Products Within
foreach (DataRow drParent in ds.Tables["LeaveTypes"].Rows)
{
lblDisplay.Text += "<h3>" + drParent["TypeName"] + "</h3><ul>";
foreach (DataRow drChild in drParent.GetChildRows("Type_Leave"))
{
lblDisplay.Text += "<li>" + drChild["loginID"] + drChild["Title"] + drChild["Reason"] + "</li>";
}
lblDisplay.Text += "</ul>";
}
}
最终效果:
关于DataRelation 更多说明,请查阅MSDN:
http://msdn.microsoft.com/zh-cn/library/system.data.datarelation%28VS.80%29.aspx
- DataRelation(DataSet中父子表)的一个示例
- DataRelation(DataSet中父子表)的一个示例
- DataRelation 实现父子表 父子级 Repeater的嵌套使用
- DataRelation 对象--多表填充DataSet
- 使用 DataSet 中的两个 DataTable 对象来创建一个 DataRelation
- c# 中DataSet示例
- DataRelation的用法(2),多表查询
- 由一个简单示例 引出java继承中父子类成员变量共享问题 以及super的使用
- javascript的事件中遍历一个dataset:
- DataRelation的用法(1)
- DataRelation
- DataRelation
- DataRelation
- DataRelation
- 通过构架dataSet读写有父子关系的xml文档
- 表中父子关系
- 从dataset(其中有可有多个不同的表)中生成一个新表的方法
- Dataset.Tables[0].Select从一个Dataset中提取符合要求的数据
- SQL优化
- (2)提示错误:当前记录集不支持更新。这可能是提供程序的限制,也可能是选定锁定类型的限制。
- 用仿ActionScript的语法来编写html5——第六篇,TextField与输入框
- wamp修改mysql数据库root密码
- Windows窗体控件线程安全
- DataRelation(DataSet中父子表)的一个示例
- 关于容器map的操作代码
- 在java + oracle环境下,对于clob类型的数据的插入
- 触发器
- launcher修改---launcher的搜索框和ProtipWidget(widget修改)(有图有真相)
- 平衡二叉搜索树(AVL树)
- 浅谈C中的malloc和free
- 实习日记041(9月16日)
- VSS+SAW配置