Solved

Epsylon's Points.

Posted on 2001-07-11
4
226 Views
Last Modified: 2010-04-06
Here you go mate.
0
Comment
Question by:MoonCalf
  • 3
4 Comments
 
LVL 13

Accepted Solution

by:
Epsylon earned 50 total points
ID: 6272673
Thanks, but I didn't solve the problem...?
0
 
LVL 1

Author Comment

by:MoonCalf
ID: 6272762
The code that you both gave me was good code, just not really 100% what I asked for.  A few bodges and it worked great.

Thanks for your help Eps
0
 
LVL 13

Expert Comment

by:Epsylon
ID: 6272772
Thank you too. Always glad to help   :o)
0
 
LVL 13

Expert Comment

by:Epsylon
ID: 6272800
Just for my reference and in case they fix the search engine   :o)

http://www.experts-exchange.com/jsp/qShow.jsp?ta=delphi&qid=20148582

Create access ODBC DSN programmatically

(* NOTE: THIS EXAMPLE IS NOT COMPLETE !!! *)

(*
 This example shows one way to load the ODBC
 Administrator's DLL (ODBCCP32.DLL) to create
 an Access MDB file and ODBC DSN pointing at
 it.  Note that it assumes current directory
 for both the DLL and the MDB, but the DLL
 will be found if in the WinSys directory which
 is where it normally is anyway.

 Similar operation applies to most driver types,
 with some modifications. eg: Access requires
 the MDB file to exist so you can hook the DSN
 to it.

 Note also that the "CREATE_DB" call is an Access
 special (MS Jet Engine) and has other variants
 like COMPACT_DB and REPAIR_DB. For a full list
 see either the Jet Engine Programmers Guide or
 the MSDN and search for "CREATE_DB".

 This was originally written in MSVC6 and was
 ported to Delphi 5.

 Full documentation can be found in the MSDN
 at http://msdn.microsoft.com/.
*)

const
 ODBC_ADD_DSN        = 1;    (* Add data source *)
 ODBC_CONFIG_DSN     = 2;    (* Configure (edit) data source *)
 ODBC_REMOVE_DSN     = 3;    (* Remove data source *)
 ODBC_ADD_SYS_DSN    = 4;    (* add a system DSN *)
 ODBC_CONFIG_SYS_DSN = 5;    (* Configure a system DSN *)
 ODBC_REMOVE_SYS_DSN = 6;    (* remove a system DSN *)

type
 TSQLConfigDataSource = function( hwndParent: HWND;
                                  fRequest: WORD;
                                  lpszDriver: LPCSTR;
                                  lpszAttributes: LPCSTR ) : BOOL; stdcall;


procedure Form1.FormCreate(Sender: TObject);
var
 pFn: TSQLConfigDataSource;
 hLib: LongWord;
 strDriver: string;
 strHome: string;
 strAttr: string;
 strFile: string;
 fResult: BOOL;
 ModName: array[0..MAX_PATH] of Char;
 srInfo : TSearchRec;
 hRegLib: HMODULE;
begin
 Windows.GetModuleFileName( HInstance, ModName, SizeOf(ModName) );
 strHome := ModName;
 while ( strHome[length(strHome)] <> '\' ) do
   Delete( strHome, length(strHome), 1 );
 strFile := strHome + 'TestData.MDB';   (* Test Access Rights (Axes =
Access) *)
 hLib := LoadLibrary( 'ODBCCP32' );     (* load from default path *)
 if( hLib <> NULL ) then
 begin
   @pFn := GetProcAddress( hLib, 'SQLConfigDataSource' );
   if( @pFn <> nil ) then
   begin
     (* force (re-)create DSN *)
     strDriver := 'Microsoft Access Driver (*.mdb)';
     strAttr := Format( 'DSN=TestDSN'+#0+
                        'DBQ=%s'+#0+
                        'Exclusive=1'+#0+
                        'Description=Test Data'+#0+#0,
                        [strFile] );
     fResult := pFn( 0, ODBC_ADD_SYS_DSN, @strDriver[1], @strAttr[1] );
     if( fResult = false ) then ShowMessage( 'Create DSN (Datasource)
failed!' );

     (* test/create MDB file associated with DSN *)
     if( FindFirst( strFile, 0, srInfo ) <> 0 ) then
     begin
       strDriver := 'Microsoft Access Driver (*.mdb)';
       strAttr := Format( 'DSN=TestDSN'+#0+
                          'DBQ=%s'+#0+
                          'Exclusive=1'+#0+
                          'Description=Test Data'+#0+
                          'CREATE_DB="%s"'#0+#0,
                          [strFile,strFile] );
       fResult := pFn( 0, ODBC_ADD_SYS_DSN, @strDriver[1], @strAttr[1] );
       if( fResult = false ) then ShowMessage( 'Create MDB (Database file)
failed!' );
     end;
     FindClose( srInfo );

     end;

   (* MASSIVE SNIP *)
   FreeLibrary( hLib );
 end
 else
 begin
   ShowMessage( 'Unable to load ODBCCP32.DLL' );
 end;
 StatusClockTimer.Enabled := true;
end;
0

Featured Post

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
Process Javascript errors with Delphi TWebBrowser 1 202
Error E2158 compiling with Delphi XE10 Seattle 2 124
PHP preg_replace code convert to Delphi 14 79
MS Access from Delphi 31 78
In this tutorial I will show you how to use the Windows Speech API in Delphi. I will only cover basic functions such as text to speech and controlling the speed of the speech. SAPI Installation First you need to install the SAPI type library, th…
Have you ever had your Delphi form/application just hanging while waiting for data to load? This is the article to read if you want to learn some things about adding threads for data loading in the background. First, I'll setup a general applica…
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…
In an interesting question (https://www.experts-exchange.com/questions/29008360/) here at Experts Exchange, a member asked how to split a single image into multiple images. The primary usage for this is to place many photographs on a flatbed scanner…

685 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