ExcelBanter

ExcelBanter (https://www.excelbanter.com/)
-   Excel Programming (https://www.excelbanter.com/excel-programming/)
-   -   writing ADODB recordset to excel sheet (https://www.excelbanter.com/excel-programming/347737-writing-adodb-recordset-excel-sheet.html)

bhavesh78

writing ADODB recordset to excel sheet
 

How can I write the data in record set to cells in excel? I have the
following code and the query always returns only ONE row. I want the
result in data set to be put on the excel sheet like say Column1 in
cell A1, column2 in cell A2 and so on...

CODE
---------------------------------


Dim ProdConnectString As String
Dim conn As New ADODB.Connection
Dim rs As New ADODB.Recordset
' String used for connecting to DB
ProdConnectString = "provider=msdaora.1;user
id=USER;password=PASS;data source =
DATASOURCE;option=1+2+8+32+2048+16384"
conn.ConnectionString = ProdConnectString
conn.CursorLocation = adUseClient
conn.Open
mySQLCriTeria = "SELECT A.Col1, A.Col2, B.Col2, B.Col3 from TBL A,
TBL B where A.Col1=B.Col1"'"
rs.Open mySQLCriTeria, conn

---------------------------------

Thanks for all the help.

-BS


--
bhavesh78
------------------------------------------------------------------------
bhavesh78's Profile: http://www.excelforum.com/member.php...o&userid=17851
View this thread: http://www.excelforum.com/showthread...hreadid=492208


Philip

writing ADODB recordset to excel sheet
 
Hi,

You need to use the CopyFromrecordset method of the range object.

For example:

range("a1").copyfromrecordset rs

This will copy the first 65525 rows to the activesheet, then you need a loop
to continue the copy on a new sheet if there are more than 65536 rows in the
recordset.

HTH

Philip

Philip

"bhavesh78" wrote:


How can I write the data in record set to cells in excel? I have the
following code and the query always returns only ONE row. I want the
result in data set to be put on the excel sheet like say Column1 in
cell A1, column2 in cell A2 and so on...

CODE
---------------------------------


Dim ProdConnectString As String
Dim conn As New ADODB.Connection
Dim rs As New ADODB.Recordset
' String used for connecting to DB
ProdConnectString = "provider=msdaora.1;user
id=USER;password=PASS;data source =
DATASOURCE;option=1+2+8+32+2048+16384"
conn.ConnectionString = ProdConnectString
conn.CursorLocation = adUseClient
conn.Open
mySQLCriTeria = "SELECT A.Col1, A.Col2, B.Col2, B.Col3 from TBL A,
TBL B where A.Col1=B.Col1"'"
rs.Open mySQLCriTeria, conn

---------------------------------

Thanks for all the help.

-BS


--
bhavesh78
------------------------------------------------------------------------
bhavesh78's Profile: http://www.excelforum.com/member.php...o&userid=17851
View this thread: http://www.excelforum.com/showthread...hreadid=492208



Philip

writing ADODB recordset to excel sheet
 
Hi,

You need to use the copyfromrecordset method of the range object.

e.g.

[a1].copyfromrecordset rs

or

range("a1").copyfromrecordset rs

If there are more than 65536 records in the recordset, you need to use a
loop and keep calling copyfromrecordset on a new sheet until the eof property
of the recordset is true.

HTH

Philip


"bhavesh78" wrote:


How can I write the data in record set to cells in excel? I have the
following code and the query always returns only ONE row. I want the
result in data set to be put on the excel sheet like say Column1 in
cell A1, column2 in cell A2 and so on...

CODE
---------------------------------


Dim ProdConnectString As String
Dim conn As New ADODB.Connection
Dim rs As New ADODB.Recordset
' String used for connecting to DB
ProdConnectString = "provider=msdaora.1;user
id=USER;password=PASS;data source =
DATASOURCE;option=1+2+8+32+2048+16384"
conn.ConnectionString = ProdConnectString
conn.CursorLocation = adUseClient
conn.Open
mySQLCriTeria = "SELECT A.Col1, A.Col2, B.Col2, B.Col3 from TBL A,
TBL B where A.Col1=B.Col1"'"
rs.Open mySQLCriTeria, conn

---------------------------------

Thanks for all the help.

-BS


--
bhavesh78
------------------------------------------------------------------------
bhavesh78's Profile: http://www.excelforum.com/member.php...o&userid=17851
View this thread: http://www.excelforum.com/showthread...hreadid=492208




All times are GMT +1. The time now is 12:08 PM.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
ExcelBanter.com