庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>程序设计>VB专区>基础教程>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

VB中远程数据库的访问(3)-应用举例

 作者:本站收集   日期:2005-8-4 11:14:04
字号选择〖 〗/ 双击滚屏 单击停止   
三、应用举例

   以上介绍了用dao访问远程数据库的具体操作,下面通过一个例子说明链接远程表和建立记录集对象的方法。

   首先建立一个新工程,在窗体上画5个命令按钮,1个数据控件和1个数据网格控件(dbgrid)。各对象的属性设置见表1。

表1 窗体1对象属性设置
对 象 标 题(caption) 名 称(name)
窗体 远程数据访问 form1
命令按钮1 链接远程表 cmdlink
命令按钮2 添加 cmdadd
命令按钮3 删除 cmddel
命令按钮4 修改 cmdmodify
命令按钮5 结束 cmdend
数据控件 data1
数据网格 dbgrid1

其中dbgrid1中的datasource属性设为data1,命令按钮2,3,4的visible属性设为false。

三、应用举例

编写如下事件过程:

private sub cmdadd_click() ' 添 加 记 录 子 过 程

on error goto errhandler

with rst

.addnew

for i = 0 to .fields.count - 1 ' 遍 历 记 录 集 中 的 每 个 字 段

' 在 输 入 框 中 输 入 各 字 段 的 数 据

.fields(i).value = inputbox

(" 输 入 记 录 信 息" & vbcr + " 字 段 名:" + .fields(i).name)

next i

.update

end with

data1.refresh

dbgrid1.rebind

errhandler: ' 错 误 处 理

select case err

case 3022, 3421

msgbox (error + vbcr + " 输 入 无 效")

exit sub

case else

response = 0

exit sub

end select

end sub

private sub cmddel_click() ' 删 除 记 录 过 程

on error goto errhandler

begintrans ' 事 务 处 理

with data1.recordset

if .bof and .eof then exit sub

' 如 果 没 有 记 录, 退 出 过 程

.delete ' 删 除

if .bof and .eof then

' 如 果 没 有 记 录, 退 出 过 程

exit sub

elseif .eof then .movelast

' 如 果 删 除 的 是 最 后 一 条 记 录, 光 标 移 至 最 后 一 记 录

else: .movenext

' 移 至 下 一 条 记 录

end if

end with

if msgbox(" 确 实 要 删 除 这 一 记 录 ?",

vbquestion + vbyesno) = vbyes then

committrans ' 确 认

data1.refresh

else

rollback ' 撤 消 改 动

data1.refresh

end if

errhandler: ' 错 误 处 理

select case err

case 3021 ' 无 当 前 记 录

msgbox (" 无 当 前 记 录, 请 选 择 要 删 除 的 记 录")

exit sub

case else

msgbox (error)

exit sub

end select

end sub

private sub cmdend_click()

end ' 结 束 应 用 程 序

end sub

private sub cmdmodify_click()

dbgrid1.allowupdate = true ' 允 许 修 改

end sub

privatev sub cmdlink_click()

form1.hide

form2.show

end sub

private sub dbgrid1_aftercolupdate(byval colindex as integer)

' 数 据 修 改 后 触 发 该 事 件

on error goto err1

data1.refresh

err1:

select case err

case 0

response = 0

case else

exit sub

end select

end sub

private sub dbgrid1_beforecolupdate

(byval colindex as integer, oldvalue as variant, cancel as integer)

' 数 据 修 改 前 触 发 该 事 件

on error goto errhandler:

begintrans

if msgbox(" 确 实 要 修 改这 一 内 容 ?", vbquestion + vbyesno) = vbyes then

committrans

else

rollback

data1.refresh

end if

errhandler:

select case err

case 0

response = 0

case else

msgbox (error)

exit sub

end select

end sub

private sub form_load()

' 在 窗 体 装 入 时, 网 格 中 的 数 据 不 可 添 加, 修 改

dbgrid1.allowaddnew = false

dbgrid1.allowupdate = false

end sub

private sub form_resize()

on error resume next

' 当 窗 体 调 整 时 会 调 整 网 格

dbgrid1.height = me.scaleheight - data1.height - cmddel.height - 30

end sub

在工程中添加一个窗体,在窗体上画6个标签,1个命令按钮(标题为“ 确认”,名称为cmd 确认),3个文本框和1个组合框。

在窗体的声明部份输入以下代码:

' 声 明 窗 体 层 变 量

dim rodbs as database

dim strdb as string, strrodb as string, strcn as string, strtdf as string

dim linktdfname as string

编 写 如 下 事 件 过 程:

private sub cmdOK_click()

on error goto errhandler:

strdb = text2.text

' 本 地 数 据 库 名 及 路 径

linktdfname = text3.text

' 本 地 数 据 库 中 新 建 的 链 接 远 程 表 的 表 名

strcn = strrodb ' 连 接 字 符 串

strtdf = combo1.text ' 指 定 远 程 数 据 库 中 要 访 问 的 表

' 调 用linktable 过 程

call linktable(strdb, strrodb, strcn, strtdf, linktdfname)

' 调 用rst_display 过 程

call rst_display(strdb, linktdfname, form1)

form2.hide

form1.show

form1.caption = " 远 程 数 据:" + strcn + "-" + strtdf

' 显 示“ 添 加”,“ 删 除”,“ 修 改” 控 件

form1.cmdadd.visible = true

form1.cmddel.visible = true

form1.cmdmodify.visible = true

errhandler:

select case err

case 0

response = 0

case else

msgbox (error + vbr + " 重 新 输 入")

exit sub

end select

end sub

private sub combo1_gotfocus()

strrodb = text1.text ' 指 定 远 程 数 据 库 名 及 路 径

set rodbs = opendatabase(strrodb) ' 打 开 远 程 数 据 库

' 删 除combo1 中 的 内 容

if combo1.listcount >= 1 then

for i = combo1.listcount - 1 to 0 step -1

combo1.removeitem i

next i

end if

' 把 数 据 库 中 的 表 名 加 到combo1 中

for i = 0 to rodbs.tabledefs.count - 1

combo1.additem rodbs.tabledefs(i).name

next i

end sub

上一篇:VB数据库数据的选项录入及选项增减与编辑    下一篇:VB中远程数据库的访问(2)-数据处理  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-8-4 11:14:04
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿