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)
- Access自定义消息盒Msg...(04.28)
- Access怎么按每个月份里面...(03.09)
- Access怎么按季度来统计人...(02.26)
- Access怎么按年龄段来统计...(01.26)
- 【Access高效办公】上一年...(12.29)
- 用Access连续窗体制作的树...(11.03)
- 【Access高效办公】上一年...(10.30)
- Access制作的RGB转CM...(09.22)
- Access制作的RGB调色板...(09.15)
学习心得
最新文章
- Access快速开发平台导航箭头改...(06.15)
- Access2024官方下载,Ac...(06.11)
- Access快速开发平台--后台A...(06.03)
- 将bit字段的Null值更新为Fa...(06.01)
- 用VBA批量更改SQL SERVE...(05.30)
- 用SQL代码更改SQL Serve...(05.29)
- Access快速开发平台--图片附...(05.29)
- 如何用VBA检查表有没有设置主键(05.28)
- 用VBA来指定图表中横坐标/纵坐标...(05.25)
- 还在凭感觉建表?Access建表思...(05.25)


.gif)
