acc本身的Dlookup,Dmax等函數应用速度測試
时 间:2008-07-11 17:06:06
作 者:fuyvn ID:43 城市:江阴
摘 要:acc本身的Dlookup,Dmax等函數应用速度測試
正 文:
經本人測度. AC 自帶 Dlookup ,Dmax 與 用 ADO 編寫的相應的替代函數 , 速度 比較結果如下.
先便出 用 ADO 寫的相應的 替代函數.
Public Conn As New ADODB.Connection 'Conn
'mLookUp 替代 AC中的 Dlookup
Public Function mLookUp(ByVal strFieldName As String, ByVal strTableName As String, Optional ByVal strWhere As String) As Variant
Dim sql As String
sql = "select " & strFieldName & " From " & strTableName
If Len(strWhere) > 0 Then sql = sql & " where " & strWhere
On Error Resume Next
mLookUp = Conn.Execute(sql)(0)
If Err <> 0 Then
Err.Clear
mLookUp = Null
End If
End Function
'mMax 替代 AC中的 DMax
Public Function mMax(ByVal strFieldName As String, ByVal strTableName As String, Optional ByVal strWhere As String) As Variant
Dim sql As String
sql = "select Max(" & strFieldName & ") From " & strTableName
If Len(strWhere) > 0 Then sql = sql & " where " & strWhere
On Error Resume Next
mMax = Conn.Execute(sql)(0)
If Err <> 0 Then
Err.Clear
mMax = Null
End If
End Function
Public Function OpenConn() As Boolean
On Error Resume Next
Set Conn = CurrentProject.Connection
'Conn.Open "Provider = Microsoft.Jet.OLEDB.4.0;Data Source = \\Server\all_user\TOFuyvn\db1.mdb"
If Conn.State = adStateClosed Then
OpenConn = False
Else
OpenConn = True
End If
End Function
測度結果:
具體數據就不一一例出. 我在群中都有發過.
結論:
如果數據庫在本機上 : Dlookup 及 DMax 比 mLookup 及 mMax 要快 70% 左右.
如果數據庫 在 局域網中的 其它電腦上, 將表 連接到 本機上: mLookup 及 mMax 比 Dlookup 及 DMax 快5 倍以上.
如果是 ADP 遠程連接 SQL 數據庫: mLookup 及 mMax 比 Dlookup 及 DMax 快 4 倍以上.
以上只是本人 自己測試的 結論, 不代表其它人的意見. 只做 參考用.
先便出 用 ADO 寫的相應的 替代函數.
Public Conn As New ADODB.Connection 'Conn
'mLookUp 替代 AC中的 Dlookup
Public Function mLookUp(ByVal strFieldName As String, ByVal strTableName As String, Optional ByVal strWhere As String) As Variant
Dim sql As String
sql = "select " & strFieldName & " From " & strTableName
If Len(strWhere) > 0 Then sql = sql & " where " & strWhere
On Error Resume Next
mLookUp = Conn.Execute(sql)(0)
If Err <> 0 Then
Err.Clear
mLookUp = Null
End If
End Function
'mMax 替代 AC中的 DMax
Public Function mMax(ByVal strFieldName As String, ByVal strTableName As String, Optional ByVal strWhere As String) As Variant
Dim sql As String
sql = "select Max(" & strFieldName & ") From " & strTableName
If Len(strWhere) > 0 Then sql = sql & " where " & strWhere
On Error Resume Next
mMax = Conn.Execute(sql)(0)
If Err <> 0 Then
Err.Clear
mMax = Null
End If
End Function
Public Function OpenConn() As Boolean
On Error Resume Next
Set Conn = CurrentProject.Connection
'Conn.Open "Provider = Microsoft.Jet.OLEDB.4.0;Data Source = \\Server\all_user\TOFuyvn\db1.mdb"
If Conn.State = adStateClosed Then
OpenConn = False
Else
OpenConn = True
End If
End Function
測度結果:
具體數據就不一一例出. 我在群中都有發過.
結論:
如果數據庫在本機上 : Dlookup 及 DMax 比 mLookup 及 mMax 要快 70% 左右.
如果數據庫 在 局域網中的 其它電腦上, 將表 連接到 本機上: mLookup 及 mMax 比 Dlookup 及 DMax 快5 倍以上.
如果是 ADP 遠程連接 SQL 數據庫: mLookup 及 mMax 比 Dlookup 及 DMax 快 4 倍以上.
以上只是本人 自己測試的 結論, 不代表其它人的意見. 只做 參考用.
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)
- 【Access高效办公】上月累...(01.06)
- 【Access Inputbo...(12.23)
- 【Access Dsum示例】...(12.16)

学习心得
最新文章
- 仓库管理实战课程(8)-商品信息功...(04.01)
- 仓库管理实战课程(7)-链接表(03.31)
- 仓库管理实战课程(6)-创建查询(03.29)
- 仓库管理实战课程(5)-字段属性(03.27)
- 设备装配出入库管理系统;基于Acc...(03.24)
- 仓库管理实战课程(4)-建表操作(03.22)
- 仓库管理实战课程(3)-需求设计说...(03.19)
- 仓库管理实战课程(2)-软件背景和...(03.18)
- 仓库管理实战课程(1)-讲师介绍(03.16)
- 统计当月之前(不含当月)的记录数怎...(03.11)