Advertisement

03.31.2004 at 06:59AM PST, ID: 20938710
[x]
Attachment Details
[x]
The Solution Rating System

With so many solutions, how can you tell which solutions are most likely to help you and which ones are not? To provide you with a tool to use, we rate our solutions based on various elements that most accurately determine if a solution is a quality solution. To explain what factors affect the solution rating, here are the elements we take into consideration when formulating our solution rating.

  • The Grade of the Solution
  • The Zone Rank of the Expert Providing the Solution
  • The Number of Author and Expert Comments
  • The Number of Experts Contributing
  • The Feedback of the Community

Your Input Matters
Because of the way the system is set up, the most important variable in this equation is you. As a member of Experts Exchange, you are able to cast your vote on the quality of the solutions in regard to how complete, accurate, helpful and easy to understand each solution is. When you provide your feedback, each rating is adjusted accordingly. So, if you see a solution that has a poor rating that you think is a good solution, let us know by rating it. As you do, the rating will be adjusted and will become more accurate for other members of our site.

If you have any suggestions that you would like to make for our rating system, please ask a question in the Suggestions Zone of Community Support.

Thank you!

ADODB recordset FetchComplete event never fires

Tags: fetchcomplete, recordset
Hi, I'm new to this, so I hope someone can help.

I'm trying to write an analysis package which takes some hefty SQL server (version 7) views and then uses the data to generate graphs etc.
The problem is that I'm trying to use an asyncronous recorcordset and then have the fetchcomplete event fire once the recordset is loaded.  This is so I can gave a nice little spinning globe while SQL server does it's stuff.

I've tested the view on SQL Query Analyser and it takes about 15 seconds to load, however in my application the fetchcomplete event never seems to fire.

I'm using Windows 2000, MDAC 2.7, VB 6 with Sp 6 loaded

Here's some of the code ... (it's running in form hence a class module)

Declarations...
Option Explicit
Dim mblnTimer As Boolean
Dim mtrv As TreeView
Dim mnd As Node
Dim mintSS As Integer
Dim WithEvents mrst As ADODB.Recordset
Dim mblnGotData As Boolean

..code that starts the recordset...

strSQL = "SELECT * FROM " & strView
cnn.CommandTimeout = 200
Set mrst = New ADODB.Recordset
With mrst
    .CursorLocation = adUseClient
    .Properties("Initial Fetch Size") = 0
    .Open Source:=strSQL, ActiveConnection:=cnn, Options:=adAsyncExecute
End With

.. code that services the fetchcomplete...

Private Sub mrst_FetchComplete(ByVal pError As ADODB.Error, adStatus As ADODB.EventStatusEnum, ByVal precordset As ADODB.Recordset)
ClearFetch
If adStatus <> adStatusOK Then
    MsgBox "Record retrieval Failed"
Else
    MsgBox "Got the data"
End If
   
   
End Sub

Any ideas anyone ?

Thanks in advance


Start your free trial to view this solution
Question Stats
Zone: Programming
Question Asked By: Natchiket
Solution Provided By: Dhaest
Participating Experts: 3
Solution Grade: A
Views: 0
Translate:
Loading Advertisement...
03.31.2004 at 09:16PM PST, ID: 10729685

Rank: Guru

All comments and solutions are available to Premium Service Members only.

Start your 7-day free trial and see for yourself why Experts Exchange is the easiest and most proven technology resource in the world. Get Started

Already a member? Login to view this solution.

 
03.31.2004 at 11:07PM PST, ID: 10730039

All comments and solutions are available to Premium Service Members only.

Start your 7-day free trial and see for yourself why Experts Exchange is the easiest and most proven technology resource in the world. Get Started

Already a member? Login to view this solution.

 
04.01.2004 at 12:49AM PST, ID: 10730459

All comments and solutions are available to Premium Service Members only.

Start your 7-day free trial and see for yourself why Experts Exchange is the easiest and most proven technology resource in the world. Get Started

Already a member? Login to view this solution.

 
04.06.2004 at 06:08AM PDT, ID: 10765471

All comments and solutions are available to Premium Service Members only.

Start your 7-day free trial and see for yourself why Experts Exchange is the easiest and most proven technology resource in the world. Get Started

Already a member? Login to view this solution.

 
04.06.2004 at 06:27AM PDT, ID: 10765644

All comments and solutions are available to Premium Service Members only.

Start your 7-day free trial and see for yourself why Experts Exchange is the easiest and most proven technology resource in the world. Get Started

Already a member? Login to view this solution.

 
04.06.2004 at 07:59AM PDT, ID: 10766556

All comments and solutions are available to Premium Service Members only.

Start your 7-day free trial and see for yourself why Experts Exchange is the easiest and most proven technology resource in the world. Get Started

Already a member? Login to view this solution.

 
06.09.2004 at 09:17AM PDT, ID: 11271560

Rank: Sage

All comments and solutions are available to Premium Service Members only.

Start your 7-day free trial and see for yourself why Experts Exchange is the easiest and most proven technology resource in the world. Get Started

Already a member? Login to view this solution.

 
06.13.2004 at 07:47AM PDT, ID: 11300084

All comments and solutions are available to Premium Service Members only.

Start your 7-day free trial and see for yourself why Experts Exchange is the easiest and most proven technology resource in the world. Get Started

Already a member? Login to view this solution.

 
 
Loading Advertisement...
Microsoft
  • Internet Protocols
  • Applications
  • Development
  • OS
  • Hardware
  • Windows Security
Apple
  • Operating Systems
  • Hardware
  • Programming
  • Networking
  • Software
Internet
  • Search Engines
  • File Sharing
  • WebTrends / Stats
  • Spy / Ad Blockers
  • Web Browsers
  • New Net Users
  • Web Development
  • Chat / IM
  • Anti Spam
  • Web Servers
  • Anti-Virus
  • Email Clients
Gamers
  • Tips
  • Online / MMORPG
  • Puzzle
  • Emulators
  • Action / Adventure
  • Role Playing
  • Consoles
  • Game Programming
  • Strategy
  • Sports
  • Misc
  • Computer Games
Digital Living
  • Hardware
  • Automotive
  • New Net Users
  • New Users
  • Software
  • Digital Music
  • Gaming World
  • Home Security
  • Apple
  • Networking Hardware
Virus & Spyware
  • Vulnerabilities
  • IDS
  • Encryption
  • Anti-Virus
  • Operating Systems Security
  • Software Firewalls
  • WebApplications
  • Cell Phones
  • Operating Systems
  • Internet
  • Hardware Firewalls
Hardware
  • Displays / Monitors
  • Handhelds / PDAs
  • Components
  • Peripherals
  • Laptops/Notebooks
  • Servers
  • Misc
  • Apple
  • Embedded Hardware
  • Networking Hardware
  • Storage
  • Desktops
  • New Users
Software
  • System Utilities
  • Industry Specific
  • Network Management
  • Photos / Graphics
  • Page Layout
  • VMware
  • Misc
  • Web Development
  • OS
  • CYGWIN
  • Voice Recognition
  • Virtualization
  • Message Queue
  • Quality Assurance
  • Security
  • Firewalls
  • MultiMedia Applications
  • Development
  • Database
  • Office / Productivity
  • Business Management
  • OS/2 Apps
  • Server Software
  • Internet / Email
ITPro
  • OS
  • Storage
  • Encryption
  • Operating Systems Security
  • Apple Hardware
  • Laptops & Notebooks
  • Servers
  • Networking Hardware
  • Peripherals
  • Devices
  • Displays / Monitors
  • WebTrends / Stats
  • Search Engines
  • Firewalls
  • Web Computing
  • WebApplications
  • IDS
  • Vulnerabilities
  • Email Clients
  • File Sharing
  • Spy / Ad Blockers
  • Web Browsers
  • Web Servers
  • Networking
  • Anti-Virus
  • Consulting
  • Chat / IM
  • Anti Spam
Developer
  • Web Servers
  • Web Browsers
  • Game Programming
  • Dev Tools
  • Industry Specific
  • Office / Productivity
  • Database
  • CYGWIN
  • Web Development
  • Search Engines
  • File Sharing
  • WebTrends / Stats
  • Programming
  • Content Management
  • Application Servers
  • Protocols
Storage
  • Removable Backup Media
  • Storage Technology
  • Servers
  • Grid
  • Remote Access
  • Backup / Restore
  • Misc
  • Hard Drives
OS
  • Miscellaneous
  • Security
  • Development
  • Linux
  • VMware
  • MainFrame OS
  • Unix
  • Apple
  • OS / 2
  • AS / 400
  • BeOS
  • Microsoft
  • VMS / OpenVMS
Database
  • Oracle
  • Miscellaneous
  • MySQL
  • Software
  • Sybase
  • Contact Management
  • PostgreSQL
  • Data Manipulation
  • Clarion
  • InterSystems Cache
  • Siebel
  • MUMPS
  • OLAP
  • SQLBase
  • SAS
  • GIS & GPS
  • 4GL
  • Berkeley DB
  • DB2
  • Informix
  • Interbase / Firebird
  • FoxPro
  • Reporting
  • LDAP
  • Filemaker Pro
  • MS SQL Server
  • dBase
  • MS Access
Security
  • Misc
  • Web Browsers
  • Software Firewalls
  • Operating Systems Security
  • File Sharing
  • Spy / Ad Blockers
  • Vulnerabilities
  • WebApplications
  • IDS
  • Anti-Virus
  • Encryption
  • Anti Spam
  • Email Clients
  • VPN
  • Chat / IM
Programming
  • Editors IDEs
  • Installation
  • Handhelds / PDAs
  • Multimedia Programming
  • System / Kernel
  • Automation
  • Algorithms
  • Game
  • Signal Processing
  • Project Management
  • Open Source
  • Database
  • Misc
  • Languages
  • Processor Platforms
  • Theory
Web Development
  • Scripting
  • Blogs
  • Web Servers
  • Software
  • Search Engines
  • Web Graphics
  • Web Services
  • Images
  • Internet Marketing
  • Images and Photos
  • Components
  • Document Imaging
  • Web Languages/Standards
  • Illustration
  • WebApplications
  • Fonts
  • WebTrends / Stats
  • Authoring
  • Digital Camera Software
  • Miscellaneous
Networking
  • Protocols
  • Apple Networking
  • Network Management
  • Message Queue
  • Application Servers
  • Content Management
  • File Servers
  • Email Servers
  • Misc
  • Java Editors & IDEs
  • Wireless
  • Networking Hardware
  • Backup / Restore
  • System Utilities
  • ISPs & Hosting
  • Web Servers
  • Storage Technology
  • Removable Backup Media
  • Servers
  • Web Computing
  • Broadband
  • Grid
  • OS / 2
  • Novell Netware
  • Unix Networking
  • Windows Networking
  • Security
  • Telecommunications
  • Operating Systems
  • Linux Networking
Other
  • Lounge
  • Business Travel
  • Community Support
  • New Net Users
  • Philosophy / Religion
  • Math / Science
  • Miscellaneous
  • URLs
  • Expert Lounge
  • Politics
  • Puzzles / Riddles
  • Automotive
Community Support
  • Suggestions
  • New to EE
  • New Topics
  • CleanUp
  • Announcements
  • General
  • Feedback
  • Input
  • EE Bugs
 
03.31.2004 at 09:16PM PST, ID: 10729685

Rank: Guru

When you try it with adAsyncFetch instead of adAsyncExecute, it should work
Set mrst = New ADODB.Recordset
With mrst
    .CursorLocation = adUseClient
         .Properties("Initial Fetch Size") = 0
         .Properties("Background Fetch Size") = 4    
         .Open strSQL, cn, , , adAsyncFetch
End With

HOWTO: Use the ADO FetchProgress and FetchComplete Events
http://support.microsoft.com/default.aspx?scid=kb;en-us;262311
Accepted Solution
 
03.31.2004 at 11:07PM PST, ID: 10730039
Well it now brings back the recordset, which is great!  However, my spinning globe doesn't work any more as the timer doesn't seem to be firing ...
 
04.01.2004 at 12:49AM PST, ID: 10730459
Have also tested with the FetchProgress event and that's not firing at all
 
04.06.2004 at 06:08AM PDT, ID: 10765471
did you put a do event in your waiting loop?
 
04.06.2004 at 06:27AM PDT, ID: 10765644
Erm... don't actually have a waiting loop... was assuming that the timer event would act as my loop.
Do you mean I should go into a loop after firing the recordset fetch ?
 
04.06.2004 at 07:59AM PDT, ID: 10766556
to be honest ,i only ue asynchronous code in VB for ftp transfer and in this case i loop after having perform some tasks and wait for a time out with a do events loop, i exit this loop on error or time out  or if the transfer was well done.
without the do events the
Private Sub Inet1_StateChanged(ByVal State As Integer) subroutine was never triggered!
this subroutine is triggered at each step of the ftp transfer
 
06.09.2004 at 09:17AM PDT, ID: 11271560

Rank: Sage

No comment has been added to this question in more than 21 days, so it is now classified as abandoned..
I will leave the following recommendation for this question in the Cleanup topic area:

Answered Dhaest

Any objections should be posted here in the next 4 days. After that time, the question will be closed.

leonstryker
EE Cleanup Volunteer
 
06.13.2004 at 07:47AM PDT, ID: 11300084
Force accepted.

modulo
CS Moderator
 
 
04.21.2008 at 06:40PM PDT, ID: 21407589
Hi all,
Iam having similar issues. Please check following code.
Please note that FetchComplete is not getting triggered. When I ran in debug mode, I could see fetchcomplete was getting called once.
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:
41:
42:
43:
44:
45:
46:
47:
48:
49:
50:
51:
52:
53:
54:
55:
56:
57:
58:
59:
60:
61:
62:
63:
64:
65:
66:
67:
68:
69:
70:
71:
72:
Option Explicit
 
Dim WithEvents Conn As ADODB.Connection
Dim WithEvents RS As ADODB.Recordset
Dim Counter As Long
Const DBConnection = "Driver={Microsoft ODBC for Oracle};Server=cruz1;UID=augustine;PWD=augustine;"
 
Private Sub Command1_Click()
    Dim iCount As Long
    iCount = 0
    If mAcctId = 0 Then
        mAcctId = 100000000
    End If
    Do While iCount < 10
        mAcctId = mAcctId + 1
        ExecuteQuery DBConnection, mAcctId
        iCount = iCount + 1
    Loop
 
End Sub
 
Private Sub Form_Load()
mAcctId = 0
Counter = 0
 
 
End Sub
 
 
Private Sub ExecuteQuery(ByVal DBConnString As String, AcctId As Long)
    
    Dim SQL As String
 
 
 
   SQL = "Select orderid from order where orderactid=999910605"
    
    If DBConnString <> "" Then
        Counter = Counter + 1
        Set RS = New ADODB.Recordset
        With RS
            .CursorLocation = adUseClient
            .Properties("Initial Fetch Size") = 0
            .Properties("Background Fetch Size") = 1
            'RS.ActiveConnection = GetConnection(DBConnString)
            RS.Open SQL, GetConnection(DBConnString), , , adAsyncFetch
          End With
    End If
End Sub
Private Function GetConnection(DBConnString As String) As ADODB.Connection
    'If Conn Is Nothing Then
        Set Conn = New ADODB.Connection
        Conn.Open DBConnString
    'End If
    Set GetConnection = Conn
End Function
 
Private Sub RS_FetchComplete(ByVal pError As ADODB.Error, adStatus As ADODB.EventStatusEnum, _
        ByVal pRecordset As ADODB.Recordset)
    Dim myConn As ADODB.Connection
    Counter = Counter - 1
    Set myConn = pRecordset.ActiveConnection
    If Not myConn Is Nothing Then
        myConn.Close
        Set myConn = Nothing
    End If
    If Not pRecordset Is Nothing Then
        If pRecordset.State <> adStateClosed Then
            pRecordset.Close
        End If
    End If    
End Sub
Open in New Window
 
 
 
20080236-EE-VQP-29