Solved

Export MS SQL Query Result to MDB file

Posted on 2007-03-28
17
430 Views
Last Modified: 2010-05-18
Hello Guys,

I need to export a result from a query to mdb access, I am trying this syntax but it is not working.

    Sql.Add('SELECT * INTO [ODBC;Driver=Microsoft Access Driver [*.mdb]; DATABASE=c:\Base.MDB;].Table1 from CONTCONTA');
0
Comment
Question by:hidrau
  • 8
  • 6
  • 3
17 Comments
 
LVL 26

Expert Comment

by:EddieShipman
ID: 18812169
what error?
0
 
LVL 21

Expert Comment

by:ziolko
ID: 18814284
i use this for excel, but maybe it will point you somewhere.

  SQL_1 = 'SELECT * INTO [Excel 8.0;Database="Z:\TestProjects\Editors\book2.xls"].[MySheet] FROM Tab1';
  SQL_2 = 'insert INTO OPENDATASOURCE'+
          '(''Microsoft.Jet.OLEDB.4.0'',''Data Source="Z:\TestProjects\Editors\MyTest.xls";Extended properties=Excel 8.0'')...[MySheet$] '+
          'select ID, Col30, Col40, Col90, Col180, Col230 FROM dat0003';

ziolko.
0
 
LVL 21

Expert Comment

by:ziolko
ID: 18814377
this works for me:
const
  SQL_21 = 'insert INTO OPENDATASOURCE'+
          '(''Microsoft.Jet.OLEDB.4.0'',''Data Source="C:\Documents and Settings\Lukasz\Desktop\nwind.mdb";'')...[MySheet4] '+
          'select Col1, Col2 FROM dat0001';

procedure TForm2.Button3Click(Sender: TObject);
var rf: Integer;
begin
  ADOConnection1.LoginPrompt:=False;
  ADOConnection1.ConnectionString:='Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Documents and Settings\Lukasz\Desktop\nwind.mdb;';
  ADOConnection1.Open;
  ADOConnection1.Execute('create table MySheet4 ('+
      'Col1 varchar(255),'+ //char(10)
          'Col2 varchar(255)'+ //char(10)
      ')',rf);

  ADOConnection1.Close;
  ADOConnection1.LoginPrompt:=True;
  ADOConnection1.ConnectionString:='Provider=SQLOLEDB.1;Persist Security Info=True;Initial Catalog=SDB;Data Source=lukaszz\sql2k;';
  ADOConnection1.Execute(SQL_21,rf);
  ADOConnection1.Close;
end;


ziolko.
0
 
LVL 1

Author Comment

by:hidrau
ID: 18814994
This line is not working

  With ADOCommand1 do
  Begin
    Str := 'SELECT * INTO [ODBC;Driver=Microsoft Access Driver [*.mdb]; DATABASE=c:\bdcc.MDB;].Table1 from CONTCONTA';
    CommandText := Str;
    Execute
 End;

I have this mdb file in my c:\
Maybe something I am doing wrongly
0
 
LVL 26

Expert Comment

by:EddieShipman
ID: 18816194
ziolko,
 I get a syntax error trying that one.
0
 
LVL 21

Expert Comment

by:ziolko
ID: 18818562
syntax error? in which point?
for me it works without any problem

ziolko.
0
 
LVL 26

Expert Comment

by:EddieShipman
ID: 18818838
Syntax error in INSERT INTO statement is all it says.

const
  SQL_21 = 'insert INTO OPENDATASOURCE'+
          '(''Microsoft.Jet.OLEDB.4.0'',''Data Source="C:\Base.mdb";'')...[Table1] '+
          'select * FROM Orders';

procedure TForm1.Button1Click(Sender: TObject);
var
  rf: Integer;
begin
  ADOConnection1.Open;
  ADOConnection1.Execute(SQL_21,rf);
  ADOConnection1.Close;
end;

ADOConnection points to Northwind DB on SQL 2K.
C:\Base.mdb is an EMPTY Access DB.
0
 
LVL 21

Expert Comment

by:ziolko
ID: 18821867
i'm confused... did you try to execute this SQL command from query analyzer?

ziolko.
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 26

Expert Comment

by:EddieShipman
ID: 18822568
NO. I'm not trying to run from QA, I'm trying to run from Delphi like you posted.
0
 
LVL 1

Author Comment

by:hidrau
ID: 18822592
EddieShipman:

I am testing your code and let me know some things.

const
  SQL_21 = 'insert INTO OPENDATASOURCE'+
          '(''Microsoft.Jet.OLEDB.4.0'',''Data Source="C:\Base.mdb";'')...[Table1] '+
          'select * FROM Orders';

In your code you use insert into opendatasource.
In my base.mdb that is in c:\ doesn't have any table inside, it is an empty database. When you use insert, the code will create this table result, is that?

I tried to run your code but I am getting an error from delphi:

[OLE/DB provider returned message: It is not possible to find the file 'c:\base.mdb'.]

the is file is in C:\

what must be wrong?

0
 
LVL 1

Author Comment

by:hidrau
ID: 18822629
Did you test in your computer your code? did it work?
0
 
LVL 21

Expert Comment

by:ziolko
ID: 18822736
Eddie confirm if i'm right
you executed insert into sql on empty access (so no table1 defined) without
executing create table sql before?

and second thing, try it in QA because if it's syntax QA will also throw error, hopefully
more detailed one:)

ziolko.
0
 
LVL 26

Expert Comment

by:EddieShipman
ID: 18823309
yes, that is what the OP wanted to do based on his other post:
http://www.experts-exchange.com/Programming/Languages/Pascal/Delphi/Q_22388210.html

If he doesn't know the field beforehand, this should just create the table for him.
0
 
LVL 26

Expert Comment

by:EddieShipman
ID: 18823551
QA throws this error:
Invalid object name 'Table1'.
Most certainly because I did not create it beforehand. But, like I just said, the OP
wants the SELECT INTO to create it.
0
 
LVL 21

Expert Comment

by:ziolko
ID: 18823821
well if theres no Table1 in access db no wonder that this part is not working :)
thats why i posted also method to create table in access:)

ziolko.
0
 
LVL 26

Expert Comment

by:EddieShipman
ID: 18823945
Ok, now, if you set the ADOConnection to point to the ACCESS database, then this works just like the OP requires. I also had to setup an ODBC DSN called "LocalServer" to point to my local SQL Server.

const
  SQL_21 = 'SELECT * INTO Orders_Backup FROM [odbc;DSN=LocalServer;' +
           'Database=northwind;].Orders';

procedure TForm1.Button1Click(Sender: TObject);
var rf: Integer;
begin
  ADOConnection1.Open;
  ADOConnection1.Execute(SQL_21,rf);
  ADOConnection1.Close;
end;

0
 
LVL 26

Accepted Solution

by:
EddieShipman earned 500 total points
ID: 18824015
This code also creates the LocalServer DSN on the fly and then removes it when it is done.

const
  SQL_21 = 'SELECT * INTO Orders_Backup FROM [odbc;DSN=LocalServer;' +
           'Database=northwind;].Orders';

procedure TForm1.Button1Click(Sender: TObject);
var
  rf: Integer;
  Reg: TRegistry;
begin
  Reg := TRegistry.Create;
  try
    with Reg do
    begin
      RootKey := HKEY_LOCAL_MACHINE;
      OpenKey('Software\ODBC\ODBC.INI\Localserver', True); // Will create it if it doesn't exist
      WriteString('Database', 'Northwind');
      WriteString('Description', 'LocalServer');
      WriteString('Driver', 'C:\WINNT\system32\SQLSRV32.dll');
      WriteString('Server', '(local)');
      WriteString('Trusted_connection', 'Yes');
      CloseKey;
      RootKey := HKEY_LOCAL_MACHINE;
      OpenKey('SOFTWARE\ODBC\ODBC.INI\ODBC Data Sources', false); // do not allow create in this
                                                                  // case since it should already exist?
      WriteString('LocalServer', 'SQL Server');
      CloseKey;
    end;

    ADOConnection1.Open;
    ADOConnection1.Execute(SQL_21,rf);
    ADOConnection1.Close;
  finally
    with Reg do
    begin
      DeleteKey('Software\ODBC\ODBC.INI\Localserver');
      OpenKey('SOFTWARE\ODBC\ODBC.INI\ODBC Data Sources', false);
      DeleteValue('LocalServer');
      CloseKey;
      Free;
    end;
  end;
end;
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Suggested Solutions

This article explains how to create forms/units independent of other forms/units object names in a delphi project. Have you ever created a form for user input in a Delphi project and then had the need to have that same form in a other Delphi proj…
Introduction Raise your hands if you were as upset with FireMonkey as I was when I discovered that there was no TListview.  I use TListView in almost all of my applications I've written, and I was not going to compromise by resorting to TStringGrid…
Get a first impression of how PRTG looks and learn how it works.   This video is a short introduction to PRTG, as an initial overview or as a quick start for new PRTG users.
This video explains how to create simple products associated to Magento configurable product and offers fast way of their generation with Store Manager for Magento tool.

932 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

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now