一、VB中集成的数据库对象
- 站在巨人的肩膀上是我们一贯的作风,那么关于vb和数据库,有哪些巨人等着我们来踩呢? 下面我来为大家介绍三个大巨人 、四个小巨人。他们是
一、大巨人 (独立对象)
- 1. connection
- 这次的系统中,主要用到了它的这两个方法。
- connection.open connectionstring
- connetion.execute sql
open 打开数据连接字符串(关于如何获取字符串connectionstring,因为之前写过这个,就不再写了。感兴趣的读者可以链接过去看看。详细介绍了关于四种数据源字符串连接的获取方式)
execute 执行 sql语句(这个没什么注意的)
2.command
这次敲系统没怎么用上,就不多说了
3.recordset
a、update 方法用来干什么?
答:更新记录,经常有同学在程序的末尾忘记加这句话,然后就会发现,语句都执行了呀! 为什么数据库中的数据没有变化? 原因就在这里。它还没有同步更新。
b、recordcount =0 的时候, eof 和bof 自然也都是 true 。因为没有记录,所以它既在第一条记录前,又在最后一条记录后。
c、 注意: 如果使用fields 属性的话,一定要清楚它是从0 开始的。 不过在这次系统开发中, 因为是以快速原型法进行开发、 数据库经常改动,我就没有怎么使用fields属性。 因为字段的位置(*)会变。 如果大家遇到和我类似的情况、推荐使用 recordset!字段名 这样的表达方式来提取数据库中的数据。
二、小巨人 依赖对象
1.field
2.parameter
3.error
4.property
本次开发的过程中只用到了 依赖对象errror 示例如下:
会对报错原因进行描述,通过查看description 属性就能知道哪里出现了问题。
二、 系统实践过程中代码的具体实现
- 因为整个系统用的最多的就是增删改查操作,所以将它写到了模块中。如下:
- public function ConnectionString() as string
- ConnectionString = "FileDSN=mycharge.dsn;UID=sa;PWD=111111"
- end function
- Public Function Executesql(ByVal sql As String,MsgString As String) As ADODB.Recordset '从数据库中检索数据
-
- Dim cnn As ADODB.Connection
- Dim rst As ADODB.Recordset
- Dim stokens() As String '生命一个变量来记录截断后的字符串
-
- On Error GoTo Executesql_Error
- Connection
-
- stokens = Split(sql) 'split 函数截断字符串
- Set cnn = New ADODB.Connection
- cnn.Open ConnectionString
- If InStr("insert,delete,update",UCase$(stokens(0))) Then '判断是否是插入,删除,更新语句 如果是,直接执行;不然就声明一个记录集,存储查询到的记录。
- cnn.Execute sql
- MsgString = stokens(0) & "query successful"
- Else
- Set rst = New ADODB.Recordset
- rst.Open Trim$(sql),cnn,adOpenKeyset,adLockOptimistic
- Set Executesql = rst
- MsgString = "查询到" & rst.RecordCount & "条记录"
- End If
- Executesql_Exit: ' 释放对象
- Set rst = Nothing
- Set cnn = Nothing
- Exit Function
- Executesql_Error:
- MsgString = "查询错误:" & Err.Description
- Resume Executesql_Exit
-
- End Function
- 调用的时候,如下所示:
- dim txtsql as string ' 记录sql语句
- dim msgtext as string ' 记录执行信息
-
- 增加记录:
- txtsql = "insert * from 表名称"
-
- 删除记录:
- txtsql= "delete * from 表名称 where 列名称 = 值 " ' 值如果是变量的话要'"& 变量名 & "'
-
- 更改记录:
- txtsql= "UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值"
-
- 查找记录
- txtsql ="select * from 表名称 where 列名称 =值"
-
- Executesql txtsql,msgtext ' 执行
-
- 如果是select语句的话
- set mrc= executesql(txtsql,msgtext)
-
- 这就是这次系统中对于vb中增删改查的收获。