【机房收费系统】VB中增删改查实践探索

前端之家收集整理的这篇文章主要介绍了【机房收费系统】VB中增删改查实践探索前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
既然软件由 程序,数据 和文档组成,那么系统自然少不了数据库的使用。 
    今天,我就给大家分享一下,我在这次实践中关于数据库基本功能——增删改查的理解和实现 。

一、VB中集成的数据库对象

站在巨人的肩膀上是我们一贯的作风,那么关于vb和数据库,有哪些巨人等着我们来踩呢? 下面我来为大家介绍三个大巨人 、四个小巨人。他们是

一、大巨人 (独立对象)

1. connection  
    这次的系统中,主要用到了它的这两个方法
connection.open  connectionstring 
connetion.execute sql

open 打开数据连接字符串(关于如何获取字符串connectionstring,因为之前写过这个,就不再写了。感兴趣的读者可以链接过去看看。详细介绍了关于四种数据源字符串连接的获取方式)

execute 执行 sql语句(这个没什么注意的)

2.command
这次敲系统没怎么用上,就不多说了

3.recordset

recordset.addnew    '增加新记录 
recordset.update   
recordset.recordcount '统计记录数,在这次系统中我用这个属性来判断信息是否输入正确。例如:
@H_404_31@if recordset.recordcount= 0 @H_404_31@then
    msgBox "信息有误,请进行核对!"
@H_404_31@else 
    txtNumber.@H_404_31@text=recordset.fields(0) 
@H_404_31@end  @H_404_31@if

a、update 方法用来干什么?

答:更新记录,经常有同学在程序的末尾忘记加这句话,然后就会发现,语句都执行了呀! 为什么数据库中的数据没有变化? 原因就在这里。它还没有同步更新。

b、recordcount =0 的时候, eof 和bof 自然也都是 true 。因为没有记录,所以它既在第一条记录前,又在最后一条记录后。

c、 注意: 如果使用fields 属性的话,一定要清楚它是从0 开始的。 不过在这次系统开发中, 因为是以快速原型法进行开发、 数据库经常改动,我就没有怎么使用fields属性。 因为字段的位置(*)会变。 如果大家遇到和我类似的情况、推荐使用 recordset!字段名 这样的表达方式来提取数据库中的数据。
二、小巨人 依赖对象
1.field
2.parameter
3.error
4.property

本次开发的过程中只用到了 依赖对象errror 示例如下:

MsgString ="查询错误:"& err.description 

会对报错原因进行描述,通过查看description 属性就能知道哪里出现了问题。

二、 系统实践过程中代码的具体实现

因为整个系统用的最多的就是增删改查操作,所以将它写到了模块中。如下:
@H_404_31@public @H_404_31@function ConnectionString() @H_404_31@as string 
ConnectionString = "FileDSN=mycharge.dsn;UID=sa;PWD=111111"
@H_404_31@end @H_404_31@function 
@H_404_31@Public @H_404_31@Function Executesql(@H_404_31@ByVal sql @H_404_31@As String,MsgString @H_404_31@As String) @H_404_31@As ADODB.Recordset '从数据库中检索数据

    @H_404_31@Dim cnn @H_404_31@As ADODB.Connection
    @H_404_31@Dim rst @H_404_31@As ADODB.Recordset
    @H_404_31@Dim stokens() @H_404_31@As String   '生命一个变量来记录截断后的字符串

    @H_404_31@On @H_404_31@Error @H_404_31@GoTo Executesql_Error
    Connection

    stokens = Split(sql)   'split 函数截断字符串
    @H_404_31@Set cnn = @H_404_31@New ADODB.Connection
    cnn.Open ConnectionString  
    @H_404_31@If InStr("insert,delete,update",UCase$(stokens(0))) @H_404_31@Then '判断是否是插入,删除,更新语句 如果是,直接执行;不然就声明一个记录集,存储查询到的记录。
        cnn.Execute sql
        MsgString = stokens(0) & "query successful"
    @H_404_31@Else
        @H_404_31@Set rst = @H_404_31@New ADODB.Recordset
        rst.Open Trim$(sql),cnn,adOpenKeyset,adLockOptimistic
        @H_404_31@Set Executesql = rst
        MsgString = "查询到" & rst.RecordCount & "条记录"
    @H_404_31@End @H_404_31@If
Executesql_Exit:     ' 释放对象
    @H_404_31@Set rst = Nothing
    @H_404_31@Set cnn = Nothing
    @H_404_31@Exit @H_404_31@Function
Executesql_Error:
    MsgString = "查询错误:" & Err.Description
    @H_404_31@Resume Executesql_Exit 

@H_404_31@End @H_404_31@Function
调用的时候,如下所示:
@H_404_31@dim txtsql @H_404_31@as string   ' 记录sql语句
@H_404_31@dim msgtext @H_404_31@as string   ' 记录执行信息

增加记录:
txtsql = "insert * from 表名称" 

删除记录:
txtsql= "delete * from 表名称 where 列名称 = 值 " ' 值如果是变量的话要'"& 变量名 & "'

更改记录:
txtsql= "UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值"

查找记录
txtsql ="select * from 表名称 where 列名称 =值"

Executesql txtsql,msgtext  ' 执行

如果是@H_404_31@select语句的话
@H_404_31@set mrc= executesql(txtsql,msgtext)

这就是这次系统中对于vb中增删改查的收获。

猜你在找的VB相关文章