您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 信息化管理 > VB6.0中DataGrid的应用
使用DataGrid控件DataGrid控件是一种类似于电子数据表的绑定控件,可以显示一系列行和列来表示Recordset对象的记录和字段。可以使用DataGrid来创建一个允许最终用户阅读和写入到绝大多数数据库的应用程序。DataGrid控件可以在设计时快速进行配置,只需少量代码或无需代码。当在设计时设置了DataGrid控件的DataSource属性后,就会用数据源的记录集来自动填充该控件,以及自动设置该控件的列标头。然后您就可以编辑该网格的列;删除、重新安排、添加列标头、或者调整任意一列的宽度。在运行时,可以在程序中切换DataSource来察看不同的表,或者可以修改当前数据库的查询,以返回一个不同的记录集合。注意DataGrid控件与VisualBasic5.0中的DBGrid是代码兼容的,除了一个例外:DataGrid控件不支持DBGrid的“解除绑定模式”概念。DBGrid控件包括在VisualBasic的Tools目录中。可能的用法查看和编辑在远程或本地数据库中的数据。与另一个数据绑定的控件(诸如DataList控件)联合使用,使用DataGrid控件来显示一个表的记录,这个表通过一个公共字段链接到由第二个数据绑定控件所显示的表。使用DataGrid控件的设计时特性可以不编写任何代码,只通过使用DataGrid控件的设计时特性来创建一个数据库应用程序。下面的说明概要地说明了在实现DataGrid控件的典型应用时的一般步骤。完整的循序渐进的指示,请参阅主题“DataGrid方案1:使用DataGrid控件创建一个简单数据库应用程序”。要在设计时实现一个DataGrid控件1.为要访问的数据库创建一个Microsoft数据链接(.MDL)文件。请参阅“创建NorthwindOLEDB数据链接”主题,以获得一个示例。2.在窗体上放置一个ADOData控件,并将其ConnectionString属性设置为在第1步中所创建的OLEDB数据源。3.在这个AdoData控件的RecordSource属性中输入一条将返回一个记录集的SQL语句。例如,Select*FromMyTableNameWhereCustID=124.在窗体上放置一个DataGrid控件,并将其DataSource属性设置为这个ADOData控件。5.右键单击该DataGrid控件,然后单击“检索字段”。6.右键单击该DataGrid控件,然后单击“编辑”。7.重新设置该网格的大小、删除或添加网格的列。8.右键单击该DataGrid控件,然后单击“属性”。9.使用“属性页”对话框来设置该控件的适当的属性,将该网格配置为所需的外观和行为。在运行时更改显示的数据在创建了一个使用设计时特性的网格后,也可以在运行时动态地更改该网格的数据源。下面介绍实现这一功能的通常方法。更改DataSource的RecordSource更改所显示的数据的最通常方法是改变该DataSource的查询。例如,如果DataGrid控件使用一个ADOData控件作为其DataSource,则重写RecordSource和刷新该ADOData控件都将改变所显示的数据。'ADOData控件连接的是Northwind数据库的'Products表。新查询查找所有'SupplierID=12的记录。DimstrQueryAsStringstrQuery=SELECT*FROMSuppliersWHERESupplierID=12Adodc1.RecordSource=strQueryAdodc1.Refresh更改DataSource在运行时,可以将DataSource属性重新设置为一个不同的数据源。例如,您可能具有若干个ADOData控件,每个控件连接不同的数据库,或设置为不同的RecordSource属性。可以简单地将DataSource从一个ADOData控件重新设置为另一个ADOData控件:'将DataSource重新设置为一个连接到Pubs数据库的、'使用Authors表的ADOData控件。SetDataGrid1.DataSource=adoPubsAuthors重新绑定DataSource当将DataGrid控件用于一个远程数据库,诸如SQLServer时,可以改变表的结构。例如,可以给这个表添加一个字段。在这种情形下,可以调用Rebind方法根据新的结构来重新创建该网格。注意,如果已经在设计时改变了这个列的布局,DataGrid控件将会试图重新创建当前的布局,包括任何空的列。不过,通过首先调用ClearFields方法,可以强制该网格重新设置所有的列。从DataGrid返回值在DataGrid被连接到一个数据库后,可能想要监视用户单击了哪一个单元。可以使用RowColChange事件——而不是Click事件。如下所示:PrivateSubDataGrid1_RowColChange(LastRowAsVariant,ByValLastColAsInteger)'显示用户所单击的单元的文字、行和列的信息。Debug.PrintDataGrid1.Text;DataGrid1.Row;DataGrid1.ColEndSub使用CellText和CellValue方法当一个列使用NumberFormat属性设置格式后,CellText和CellValue属性是很有用的。NumberFormat属性不必更改实际的数据格式就可以更改任何包含数字的列的格式。例如,给定一个网格,其中包含一个名为ProductID的、包含整数的列。下面的代码将使DataGrid以P-0000的格式来显示数据。换句话说,尽管在ProductID字段中所包含的实际数值为3,但该网格所显示的值将是P-0003。PrivateSubForm_Load()DataGrid1.Columns(ProductID).NumberFormat=P-0000EndSub要返回数据库中所包含的实际值,应使用CellValue方法,如下所示:PrivateSubDataGrid1_RowColChange(LastRowAsVariant,ByValLastColAsInteger)Debug.Print_DataGrid1.Columns(ProductID).CellValue(DataGrid1.Bookmark)EndSub注意上面所用的CellValue和下面所用的CellText值,都需要将Bookmark属性作为一个参数,功能才正确。相反地,如果要返回该字段的格式化的值,应使用CellText方法:PrivateSubDataGrid1_RowColChange(LastRowAsVariant,ByValLastColAsInteger)Debug.Print_DataGrid1.Columns(ProductID).CellText(DataGrid1.Bookmark)EndSub注意上面的CellText方法等价于使用DataGrid控件的Text属性。下一步要阅读关于使用该控件创建简单的应用程序的一个循序渐进的过程,请参阅“使用DataGrid控件创建简单的数据库应用程序”,或“创建一个连接DataList控件的DataGrid”。要了解关于Split对象以及如何对其编程的详细信息,请参阅“操作DataGrid视图”。创建Northwind的OLEDB数据链接访问数据的一个重要步骤是为想要访问的每个数据库都创建一个OLEDB数据源。下面的步骤为VisualBasic所提供的Nwind.mdb(Northwind)数据库创建这样一个对象。这个数据源被用于VisualBasic文档所提供的一些示例过程。在一个计算机上只需要创建一次OLEDB数据源。要创建Northwind的OLEDB数据源1.打开WindowsExplorer或WindowsNTExplorer。2.打开您想要创建OLEDB数据源的目录。在该示例中,打开ProgramFiles、MicrosoftVisualStudio和VB98。3.右键单击Explorer的右边窗格,然后单击上下文菜单上的“新建”。从文件类型列表中单击“Microsoft数据链接”。4.重命名新文件Northwind.MDL。5.右键单击文件并单击上下文菜单上的“属性”,以显示“Northwind.MDLProperties”对话框。6.单击“连接”选项卡。7.单击“提供方”框并选择“MicrosoftJet3.51OLEDBProvider”。8.在DataSource框中输入nwind.mdb文件的路径。9.单击“测试连接”,检测连接。10.如果连接通过,单击“确定”。注意也可以通过在“控制面板”中单击“数据链接”图标创建一个OLEDB数据源。在“管理数据链接文件”对话框中,单击“新建”创建一个新的数据源。使用DataGrid和ADOData控件创建一个简单的数据库应用程序只使用一个DataGrid和一个ADOData控件,可以创建一个允许最终用户阅读和写入记录集的数据库应用程序。要使用ADO数据控件来创建一个简单的数据库应用程序1.为Northwind数据库创建一个OLEDB数据源。如果还没有创建数据源,请按照“创建Northwind的OLEDBDataLink”中的步骤操作。2.在VisualBasic中创建一个新的标准的EXE工程。如果DataGrid控件不在“工具箱”中,则用右键单击“工具箱”,然后使用“部件”对话框来添加控件。同时也载入ADO控件。3.在空窗体上各放置控件的一个实例。4.将ADO控件的ConnectionString属性设置为Northwind的数据源。单击并选定该ADOData控件,并按F4键出现“属性”窗口。单击“ConnectionString”,然后单击OLEDBFile。单击Northwind的数据源。5.设置ADO控件的RecordSource属性。在“属性”窗口中,单击“记录源”并输入一条SQL语句来填充DataGrid控件。在本例中,输入“Select*FromProducts”。6.将DataGrid控件的DataSource属性设置为这个ADOData控件。单击并选定该DataGrid控件。在其“属性”窗口中,单击“数据源”将出现一个包含所有数据控件的下拉列表——在本例中只有ADOData控件。单击这个控件。7.按F5键运行这个工程。创建一个连接DataList控件的DataGridDataGrid的通常用法是显示数据库的一个表所提供的“详细内容”。例如,Northwind(Nwind.mdb)数据库包括两个表,一个名为Suppliers,另一个名为Products。在本例中,我们使用DataList控件来显示Suppliers表中的供应商的公司名称。当用户单击任意一个公司名称时,这个DataList控件将提供该公司的SupplierID。使用这个标识符,就可以构造一个查询,在Products表中检索具有相匹配的SupplierID的所有记录。换句话说,当用户单击一个公司时(在DataList控件中),该公司生产的所有产品将出现在DataGrid控件中。要使用一个指定供应商的产品填充一个DataGrid控件1.确认在机器上已为Northwind数据库建立了一个OLEDB数据源;如果还没有创建这样的一个数据源,请按照“创建Northwind的OLEDBData连接”的步骤操作。2.在VisualBasic中创建一个新的标准的EXE工程。如果DataGrid、DataList和ADOData控件不在“工具箱”中,则右键单击“工具箱”,然后单击“部件”。在“部件”对话框中双击“MicrosoftDataGridControl”、“MicrosoftDataListControls”以及“MicrosoftADOControl”。3.在一个空窗体中各放置一个DataGrid和DataList控件的实例。将DataL
本文标题:VB6.0中DataGrid的应用
链接地址:https://www.777doc.com/doc-2853916 .html