用类来编写数据库程序
原作者:www.upwinder.com 添加时间:2007-09-02 原文发表:2007-08-31 人气:8 来源:未知 本文章共2059字,分2页,当前第1页,快速翻页:1 2 类模块使VB 编程更为简洁。通过封装技术将复杂的代码同程序的其它部分分隔开,并通过方法和属性 同程序的其它部分对话。对于类的种种好处,相信大家都非常清楚了。本文主要介绍类在数据库 编程方面的应用。 逆风编程技术 通过类模块的封装,你可以只需要书写一次那些冗长繁人的SQL查询语句,并能方便地同他人分享你的代码。本文向你介绍如何利用类模块创建SQL查询对象。本文用到Northwind数据库 。数据访问技术用的是DAO。 工程目的 本工程的目的是要建立一个查询,该查询将从Northwind数据库 中返回Beverage供应商的信息。这些信息包括哪种饮料是由哪些供应商供应的。看上去很简单,但你得对三个表进行操作,这三个表分别是Suppliers, Categories和Products, 因此你需要写一串很长的SQL查询语句,所以你只希望写一次就够了。 设计类模块 首先确认你已添加了对Microsoft DAO 3.5 Object Library的引用。接下来在工程中添加一个类模块。将该类模块重命名为ClsSQL。 让我们先为这个类创建两个新的公共属性 ,代码如下: Public CompanyName As String 'Object property Public CategoryName As String 'Object property 添加一个公用变量,名为strMsg。该变量用来保存对象返回给用户的信息。 Public CompanyName As String 'Object property Public CategoryName As String 'Object property Public strMsg As String 现在为这个类编写RunQuery方法。 Sub RunQuery() Dim strSQL As String Dim db As Database Dim qdfTemp As QueryDef Dim rsResults As Recordset 'Construct the SQL string strSQL = "SELECT DISTINCTROW Suppliers.CompanyName, " & "Products.ProductName FROM Suppliers INNER JOIN " & "(Categories INNER JOIN Products ON Categories.CategoryID = " & "Products.CategoryID) " & "ON Suppliers.SupplierID = Products.SupplierID " & "WHERE (((Suppliers.CompanyName)='" & CompanyName & "') AND " & "((Categories.CategoryName)='" & CategoryName & "'))" Set db = OpenDatabase("C:\MSOffice\ACCESS \Samples\Northwind.mdb") Set qdfTemp = db.CreateQueryDef("") qdfTemp.SQL = strSQL Set rsResults = qdfTemp.OpenRecordset(dbOpenSnapshot) rsResults.MoveFirst 'Enumerate the recordset With rsResults Do While Not .EOF Debug.Print .Fields(0); " "; .Fields(1) strMsg = strMsg & .Fields(1) & VB CrLf .MoveNext Loop End With rsResults.Close qdfTemp.Close End Sub 现在让我们来简单地分析一下上面的代码。在上面的代码中数据库的路径是用的绝对路径。如果Northwind数据库的路径同你机器上的不同,你需要修改这个路径,以便程序能找到这个数据库 。 SQL代码是在ACCESS 中建立好然后粘贴到程序中来的。这样做不仅免去你书写代码的麻烦,而且还不容易出错。在粘贴完之后,将原来在SQL代码中的"Bigfoot Breweries" 和 "Beverages"用公共变量CompanyName和CategoryName替换掉。 在定义了QueryDef之后,程序枚举记录集。记录集的信息不仅在立即窗口中显示出来,同时被写入strMsg变量中。 在结束对类模块的编码之前,我们还需要对类模块的Terminate事件编写代码。将下面的代码放到该事件 中。 Private Sub Class_Terminate() MsgBox strMsg, Title:="Beverage Results for " & CompanyName, buttons:=VB Exclamation End Sub 现在我们已结束了对类模块的编程。接下来在窗体中添加一个命令按钮。将该命令按钮的Caption属性 设置为&Run Query。将下面的代码放在命令按钮的鼠标单击事件 中。 Private Sub Command1_Click() Dim objSQL As ClsSQL 'Set the object variable Set objSQL = New ClsSQL 'Set properties of the new object With objSQL 本文章更多内容 :1 - 2 - 下一页>>
本文章所属分类:
首页
→ VB
文章搜索
热门文章
推荐文章
最新文章