频 道 直 达 - 新闻 - 读书 - 培训 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 技术圈 - 博客 - BBS
51CTO.COM_中国领先的IT技术网站
找资料:

VisualBasic.NET实现主/从数据表视图(1)

作者: 出处:.NET文档  (  ) 砖  (  ) 好  评论 ( ) 条  进入论坛
更新时间:2006-12-08 00:42
关 键 词:.NET  VB    从数据表  视图
阅读提示:主/从数据表是浏览关联数据表的有效模式,本文简单介绍了实现主/从数据表视图的两种方式。利用主/从数据表模式,能在较小的编程工作量下,实现很好的显示及操作效果。若要建立多表关联的主/从视图,或是进行增、删、改等操作,在此方法上进行改进即可。

一、简介

在以数据库为中心的应用程序中,主/从数据表视图是一种非常常见的设计模式。在这种模式下,顶级数据(主表)显示在一个用户界面元素中(如Data Grid),而与之相关的细节数据(从表)则根据主表的选择作相应的变化更新。例如:我们可以查看出版社已出版图书的信息列表,当选择某种图书时,在从表中立即显示出该图书的销售情况。

在.NET中实现主/从数据表模式一般有两种方式,一是利用一个Data Grid控件装入两个相关的数据表,二是采用两个Data Grid控件实现主从模式。为便于说明,我们采用SQL Server 2000自带的Pubs数据库的Titles表和Sales表进行演示,其中Titles表记录了某出版社的图书目录,而Sales表则是每种图书的销售数据,两张表中都包含title_id列。

二、一个data Grid中装入多个相关表

我们都知道,将Data Grid的Data Source属性同Dataset相绑定,即可将数据表显示在Data Grid中,但不少初学者并不清楚:通过向Dataset中添加多个Data Table对象,每个Data Table对象装入一张表,再设定好关联,即可在Data Grid中显示多张关联表。

Imports System.Data.SqlClient

’引用SqlClient命名空间
Public Class Form1
Const Connection String As String = "integrated security=sspi;

initial catalog=Pubs; data source=(local)"
’定义连接字符串
Private Sub Button1_Click(By Val sender As Object,

By Val e As System.EventArgs) Handles Button1.Click
 Dim cn As New SqlConnection (Connection String)
 Cn. Open()
 ’建立同数据库的连接
 Dim ds As New Dataset("Book Sales")
 ’创建Dataset对象
 Dim Titles Table As New Data Table("Titles")
 ds.Tables.Add(Titles Table)
 ’创建Data Table对象(Titles表),加入Dataset
 Dim GetTitlesString As String = "Select * From Titles"
 Dim da As New SqlDataAdapter(GetTitlesString, cn)
 da.Fill(Titles Table)
 ’填充Data Table
 da.Dispose()
 Dim Sales Table As New Data Table("Sales")
 ds.Tables.Add(Sales Table)
 Dim GetSalesString As String = "Select * From Sales"
 da = New SqlDataAdapter(GetSalesString, cn)
 da.Fill(Sales Table)
 ’创建并填充Sales表
 da.Dispose()
 cn.Close()
 Dim relation As New Data Relation("Title Sales",

TitlesTable.Columns("title_id"),SalesTable.Columns("title_id"))
 ds.Relations.Add(relation)
 根据title_id列建立两个表的关联
 DataGrid1.DataSource = ds
 将DataGrid1绑定到Dataset对象(即ds)
End Sub
End Class

需要注意的是:在单表模式下,用SqlDataAdapter对象填充Dataset时,若发现Dataset中没有表,就自动创建一个新的Data Table并填充;而用主从模式时,应显示创建每个Data Table对象并填充,再利用Data Relation对象建立多个Data Table之间的关联,最后将Data Grid绑定到Dataset上。

图1:Data Grid中装入两张表

运行工程,会看到一个有加号按钮的视图。单击加号,窗体中出现装入的所有表名,如图1。如果查看Titles表,就会发现在每行的旁边有一个小加号按钮,点击加号,就可以查看其销售情况,如图2、图3。

图2:主表情况

图3:从表情况

在窗体的右上部,向左的小箭头按钮用于回退。每查看一次销售情况后,都必须用回退按钮回到主表,显然,这种主/从表模式的可操作性很差,也不太符合我们的操作习惯。也许,后一种方式是比较好的解决方案。


共2页: 1 [2] 下一页
【内容导航】
发表
查看
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 领 先 的 IT 技 术 网 站 ·
技 术 成 就 梦 想
·Java基础教程 (查看52473次)
·UML类图详解 (查看46951次)
·Java编程开发手册 (查看25172次)
·UML统一建模语言 (查看24155次)
·C#技术开发指南 (查看22515次)
·Java编程开发手册 (1195个砖)
·Java基础教程 (429个砖)
·C#技术开发指南 (304个砖)
·PB开发教程 (220个砖)
·.NET开发手册 (217个砖)
·Java编程开发手册 (653个好)
·Java基础教程 (569个好)
·.NET开发手册 (251个好)
·PB开发教程 (209个好)
·Delphi开发技术手册 (174个好)
订阅技术快讯
电子杂志下载
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
名称:Vista精品应用黄皮书
简介:《Vista精品应用黄皮书》囊括了Vista的各方面内容。此次的精简版,是将里面的内容做了提取,便于用户下载和使用。内容包含了各种Vista的安装与实施、技巧与解析以及各种Vista相关学习文档和相关软件的安全下载。该电子书是了解和应用Vista人员必备的工具手册,并且也是第一本
名称:2006中国IT论坛精品集合
简介:本书由“51CTO论坛推广联盟”制作完成。书中所有内容均来自各联盟成员的论坛(网站)。制作本书的目的是为了集中大家的优势资源,将更多更精彩的内容带给广大技术爱好者。本书是联盟成立以来制作的第一本书。
关键字阅读
频道精选
主编信箱 热线:010-66476606 告诉我们您想看的:专题 文章
关于我们 | 诚聘英才 | 联系我们 | 网站大事 | 意见反馈 | 网站地图
Copyright©2005-2007 51CTO.COM 版权所有