精彩编程与编程技巧-建立、改变及重构Access数据库...
### 知识点详解 #### 一、Access 数据库简介 Microsoft Access 是一款常见的桌面关系型数据库管理系统(RDBMS),被广泛应用于中小型企业、学校等机构的数据管理场景。Access 提供了图形化的用户界面,使得非专业人员也能轻松创建、管理和维护数据库。 #### 二、使用 VB 编程来操作 Access 数据库 在实际开发工作中,通过编程语言如 Visual Basic (VB) 来操作 Access 数据库是非常常见的做法。这不仅可以提高工作效率,还能实现更复杂的功能需求。 ##### 1. 创建数据库表结构 通过 VB 编写脚本来创建数据库表结构是一种高效的方法。下面是一个示例代码片段,展示了如何定义一个包含几个字段的表结构: ```vb ReDim sTables(300, 3) As String sTables(1, 1) = "lPersonID" sTables(1, 2) = "Long" sTables(1, 3) = "person's ID" sTables(2, 1) = "sPersonFirstName" sTables(2, 2) = "Text" sTables(2, 3) = "20" sTables(3, 1) = "sPersonLastName" sTables(3, 2) = "Text" sTables(3, 3) = "20" sTables(4, 1) = "bIsAFunPerson" sTables(4, 2) = "Boolean" sTables(5, 1) = "iTypeOfJob" sTables(5, 2) = "Integer" sTables(6, 1) = "iAge" sTables(6, 2) = "Integer" ``` 在这个例子中,我们定义了一个包含六个字段的表:`lPersonID`、`sPersonFirstName`、`sPersonLastName`、`bIsAFunPerson`、`iTypeOfJob` 和 `iAge`。每个字段都指定了其数据类型和必要的长度信息。 ##### 2. 使用 CSV 文件定义表结构 在实际应用中,经常需要从 CSV 文件读取表结构定义,并将其导入到 Access 数据库中。以下是一个简单的 VB 函数,用于实现这一过程: ```vb Sub CreateTable(sDatabaseName As String, sCSVFileName As String, sTableName As String) Dim iTemp As Integer ' 权限检查 iTemp = DoEvents() ' 定义二维数组存储表结构 ReDim sTables(300, 3) As String ' 读取 CSV 文件中的表结构定义 Call ReadTableDefinition(sCSVFileName, sTables()) Dim tbl As New TableDef Dim fld As Field Dim dbPersons As Database ' 打开数据库 Set dbPersons = OpenDatabase(sDatabaseName & ".MDB", True) ' 创建表对象 tbl.Name = sTableName Set fld = New Field fld.Name = sTables(1, 1) fld.Type = GetFieldType(sTables(1, 2)) fld.Size = Val(sTables(1, 3)) tbl.Fields.Append fld ' 添加表到数据库 dbPersons.TableDefs.Append tbl ' 循环添加其他字段 Dim iNextCol As Integer iNextCol = 1 Do While True Set fld = New Field iNextCol = iNextCol + 1 If sTables(iNextCol, 1) = "***END***" Then Exit Do End If fld.Name = sTables(iNextCol, 1) fld.Type = GetFieldType(sTables(iNextCol, 2)) If Len(sTables(iNextCol, 3)) > 0 Then fld.Size = Val(sTables(iNextCol, 3)) End If tbl.Fields.Append fld Loop End Sub ``` 这段代码首先打开指定的 Access 数据库文件,然后根据 CSV 文件中的定义创建表结构。它通过循环读取 CSV 文件中的每一行数据来定义表中的字段,并将这些字段添加到新创建的表中。 ##### 3. 其他相关知识点 - **字段类型**:在 Access 数据库中,字段可以有不同的数据类型,如文本、数字、日期/时间等。 - **字段大小**:对于某些字段类型,如文本字段,需要指定其最大长度。 - **数据类型转换**:在从 CSV 文件读取数据时,可能需要进行数据类型的转换处理,确保与 Access 数据库中字段的数据类型相匹配。 - **错误处理**:在编写这样的脚本时,需要考虑各种可能出现的错误情况,并添加适当的错误处理机制,例如检查 CSV 文件是否存在、格式是否正确等。 通过上述方法,我们可以有效地利用 VB 脚本来创建和管理 Access 数据库,提高数据管理的效率和灵活性。这对于那些需要频繁修改数据库结构或者自动化处理数据的应用来说是非常有用的。
由VB提供的DataManager对于开发人员来讲并不是一件强大的工具。对于那些没有装Access数据库的人来说,在开发时建立.改变或重构数据库,以及载入/重载表单都是一件痛苦的事。此外DataManager不能让我们打印数据库的结构。
让我们编一个小程序实现上述功能,然后工程结束后把它抛弃.
首先可以用一个以逗号分隔的文本文件来储存表结构,如下面这个人员表。
lPersonID,Long,,person's ID
sPersonFirstName,Text,20,person's first name
sPersonLastName,Text,20,person's last name
bIsAFunPerson,Boolean,,invite to a party?
iTypeOfJob,Integer,,0=None 1=Manual 2=Office 3=programmer etc.
iAge,Integer,,person's age
该表有六列,每列独占一行。每行中用逗号分隔下列各项:字段名.字段类型.字段长度(如果不是字符型字段,就留空,仅用逗号分隔)及字段描述。如果你想在字段描述中使用逗号,你可以不用逗号分隔各项,
换成Tab分隔。
一个通用程序能读取这些文件并根据它们建立起数据库。这种方法,连同一些通用的导入/导出程序能大大加快程序开发的速度。举例 来说,你不能在DM中删除一个表的一列,但通过删除CSV文件中对一列的定义,然后重新运行构建数据库的程序,你就能轻松做到这一点。
如果你想打印出数据库的结构,方法也很简单:用Excel读CSV文件,再将其粘贴到Word中,这样你就可以打印出整个数据库的结构了。
下面是程序代码:
Sub CreateTable (sDatabaseName As String, sCSVFileName As String,
sTableName As String)
Dim iTemp As Integer
'将控制权交还给操作系统,使其在创建数据库的同时能运行其它程序-别让你的计算机闲着!
iTemp = DoEvents()
'创建一个300X3数组
ReDim sTables(300, 3) As String
- 粉丝: 22
- 资源: 3095
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助