Solved

Insert ADO recordset to table

Posted on 2014-03-11
10
3,691 Views
Last Modified: 2014-03-13
Hi,

I have a VBA that queries a database and gets a set of data into a recordset.  I need a way to copy this data into the table.   The recordset and the table both have a same structure (1 column) and the recordset is usually large (100,000 rows) and the table is cleared before it is filed with the data.

Any way I can do an insert that copies whole recordset into table?

I've seen lots of examples where we go through each recordset and do an insert, but due to the size, i can't imagine this method being efficient.
0
Comment
Question by:iamnamja
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 6
  • 3
10 Comments
 
LVL 57
ID: 39920752
<<Any way I can do an insert that copies whole recordset into table? >>

  In short, no.    But what you can do is execute an INSERT with a SELECT based on the one you just used to get the record set.

Jim.
0
 

Author Comment

by:iamnamja
ID: 39920782
Hi Jim,

Could you give me an example of how this would work?


Here's my current code inserting line by line..

all_SQL = "SELECT distinct i.sid " & _
            "FROM common..idlist i"


Set all_RS = query_DB(globconn, all_SQL)

DoCmd.SetWarnings False
DoCmd.RunSQL "DELETE * FROM Latest_TIDs"
DoCmd.SetWarnings True

If all_RS.State <> 0 Then
    If Not (all_RS.EOF And all_RS.BOF) Then
        all_RS.MoveFirst
        DoCmd.SetWarnings False
        Do While Not all_RS.EOF
            DoCmd.RunSQL "INSERT INTO Latest_SIDs (sid) VALUES(""" & all_RS!sid.Value & """)"
            all_RS.MoveNext
        Loop
        DoCmd.SetWarnings True
    End If
End If

Open in new window

0
 
LVL 57
ID: 39920882
all_SQL = "INSERT INTO Latest_SIDs ( SID ) SELECT distinct i.sid FROM common..idlist i"

CurrentDB.Execute all_SQL, dbFailOnError

This assumes the tables are available as linked tables as with CurrentDB().Execute or DoCmd.RunSQL, you are not using ADO to execute the query (linked tables use ODBC).

Jim.
0
Ransomware-A Revenue Bonanza for Service Providers

Ransomware – malware that gets on your customers’ computers, encrypts their data, and extorts a hefty ransom for the decryption keys – is a surging new threat.  The purpose of this eBook is to educate the reader about ransomware attacks.

 

Author Comment

by:iamnamja
ID: 39920888
Hi Jim,

Unfortunately the tables are NOT linked - actually can't be linked, so i would need to query it the way I did above.  Does that mean the only method is the way that I have currently written?
0
 
LVL 57
ID: 39921082
<<Unfortunately the tables are NOT linked ->>

 I don't understand how your RunSQL works then.

Jim.
0
 
LVL 57
ID: 39921096
<<Does that mean the only method is the way that I have currently written? >>

 missed this...no, you can execute the SQL via ADO:

<connection object>.Execute all_SQL

Jim.
0
 

Author Comment

by:iamnamja
ID: 39921240
So just so that we're on the same page... The all_rs query is run on a sybase database and the recordset data fetched is what i need to store into my table called Latest_SIDs.

How do i run a query that inserts a data from a sybase database into access?
0
 
LVL 57

Accepted Solution

by:
Jim Dettman (Microsoft MVP/ EE MVE) earned 500 total points
ID: 39921632
ah, so Latest_SIDs  is local...now I understand the problem.

In that case, you will need to use the IN clause on the select statement to specify the external database.   With that, you must call an ODBC driver.   Basically, your doing a linked table on the fly.  Will look something like this:

all_SQL = "INSERT INTO Latest_SIDs ( SID ) SELECT distinct i.sid FROM common..idlist IN '' [ODBC; Driver={MySQL ODBC 5.2 ANSI Driver};Server=localhost;Database=myDataBase;
User=myUsername;Password=myPassword;Option=3;"

CurrentDB.Execute all_SQL, dbFailOnError

Your connection info will vary of course, but that's the jist of it.   You probably can do this with ADO as well, but off-hand I don't know how.

Jim.
0
 
LVL 37

Expert Comment

by:PatHartman
ID: 39921754
I don't understand why you can't link the table.  The link doesn't need to be permanent.  You can use TransferDatabase to link and then delete the link when you are done.
0
 
LVL 57
ID: 39921957
A linked table is faster performance wise too...

Jim.
0

Featured Post

Online Training Solution

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action. Forget about retraining and skyrocket knowledge retention rates.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Access custom database properties are useful for storing miscellaneous bits of information in a format that persists through database closing and reopening.  This article shows how to create and use them.
Did you know that more than 4 billion data records have been recorded as lost or stolen since 2013? It was a staggering number brought to our attention during last week’s ManageEngine webinar, where attendees received a comprehensive look at the ma…
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…
In Microsoft Access, learn the trick to repeating sub-report headings at the top of each page. The problem with sub-reports and headings: Add a dummy group to the sub report using the expression =1: Set the “Repeat Section” property of the dummy…

751 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question