Microsoft KB Archive/186267

= PRB: MaxRecords Property Is Not Used in Access Queries with ADO =

Article ID: 186267

Article Last Modified on 3/2/2005

-

APPLIES TO


 * Microsoft ActiveX Data Objects 1.0
 * Microsoft ActiveX Data Objects 1.5
 * Microsoft ActiveX Data Objects 2.0
 * Microsoft ActiveX Data Objects 2.1 Service Pack 2
 * Microsoft ActiveX Data Objects 2.5
 * Microsoft ActiveX Data Objects 2.6
 * Microsoft ActiveX Data Objects 2.7

-



This article was previously published under Q186267



SYMPTOMS
Using the MaxRecords property of an ADO Recordset object does not affect the number of records returned in queries against Microsoft Access databases.



CAUSE
The MaxRecords property depends on functionality exposed by the underlying OLE DB provider or ODBC driver to limit the number of rows returned by the query. This functionality is optional for ODBC drivers and OLE DB providers. The Microsoft Access ODBC driver and Jet OLEDB provider do not expose this functionality. This behavior may occur for other OLE DB providers and ODBC drivers as well.



RESOLUTION
If you want to limit the number of records returned in a query against a Microsoft Access database, use the TOP syntax in the query string rather than the Recordset's MaxRecords property.



STATUS
This behavior is by design.



Steps to Reproduce Behavior
Instead of using the following code: strSQL = "SELECT * FROM Customers" rsCustomers.MaxRecords = 10 rsCustomers.Open strSQL, cnNWind, adOpenStatic MsgBox rsCustomers.RecordCount & " records returned using MaxRecords." Use this code: strSQL = "SELECT TOP 10 * FROM Customers" rsCustomers.Open strSQL, cnNWind, adOpenStatic MsgBox rsCustomers.RecordCount & " records returned using TOP syntax." With the first snippet of code, you should see that the MaxRecords property does not affect the number of records returned by the query. The second snippet of code should return only ten records.

Keywords: kbdatabase kbjet kbdcom kbprb kbmdacnosweep KB186267

-

[mailto:TECHNET@MICROSOFT.COM Send feedback to Microsoft]

© Microsoft Corporation. All rights reserved.