频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

三层架构之数据库访问层(VB)

来源: 作者: 出处:巧巧读书 2006-09-14 进入讨论组

  '########数据库访问层##########


'返回一个ADOCN连接对象

'与C#不同,这里不能关闭连接及释放内存
Public Function GetCN(sDBPath As String) As ADODB.Connection


Const sPro As String = "provider=microsoft.jet.oledb.4.0;data source="
Const sDBPWD As String = ";jet oledb:database password=QQ:48403849"

Dim sDBPath As String
Dim m_cn As ADODB.Connection



Set m_cn = New ADODB.Connection

m_cn.CursorLocation = adUseClient '客户端游标

If m_cn.State <> adStateClosed Then m_cn.Close

On Error GoTo conerr

m_cn.Open sPro & sDBPath & sDBPWD

Set GetCN = m_cn

Exit Function
conerr:
Set GetCN = Nothing
MsgBox "数据库连接错误", vbCritical

End Function

'执行一句SQL语句,正确返回 1
Public Function ExcuteSQL(sSQL As String) As Integer
Dim m_cn As New ADODB.Connection

On Error GoTo err

Set m_cn = GetCN(sG_DBPath)
m_cn.Execute sSQL
m_cn.Close
Set m_cn = Nothing
ExcuteSQL = 1

Exit Function
err:
ExcuteSQL = 0
Set m_cn = Nothing


End Function
'执行一组SQL语句,正确返回1
Public Function ExcuteSQLEX(sSQL() As String) As Integer
'调用事务处理
Dim m_cn As New ADODB.Connection, i As Integer

If UBound(sSQL) < 0 Then Exit Function
On Error GoTo err

Set m_cn = GetCN(sG_DBPath)

m_cn.BeginTrans
For i = 0 To UBound(sSQL) - 1
m_cn.Execute sSQL(i)
Next i

m_cn.CommitTrans
m_cn.Close
Set m_cn = Nothing

ExcuteSQLEX = 1

Exit Function
err:
ExcuteSQLEX = 0
m_cn.RollbackTrans
m_cn = Nothing

End Function


'未完,待补充文字:http://www.qqread.com/vb/s236336.html 更多文章 更多内容请看数据库专栏数据库处理专题城域网专题专题,或进入讨论组讨论。
收藏此文】【 】【打印】【关闭
较早的文章:如何做旋转的光盘动画

较新的文章:三维字的实现
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
最新论坛文章
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章