VC + ADO Dynamic Create Access Database

xiaoxiao2021-03-06  52

VC ADO Dynamic Create Access Database

ADO technology has now become the mainstream technology for connecting the database. Here I will show how to use ADO to dynamically create an Access database.

To use ADO, you must introduce Microsoft's two dynamic connection libraries Msadox.dll and Msado15.dll:

#pragma Warning (Disable: 4146) #import "c: / program files / common files / system / ado / msadox.dll" #import "c: / program files / common files / system / ado / msado15.dll" no_namespace rename ("Eof", "endoffile" # Pragma Warning (Default: 4146)

Add the above code to the stdafx.h file, because the ADO is a COM component, so I will initialize the COM environment before using ADO:

Coinitialize (NULL);

Below is an example of a SQL statement that creates a table in the Access database:

Create Table Test (nametext (20) with compression not null,

ScoreDecimal (12, 4) Not Null Default 0,

ID Smallint Not Null Default 0,

BIRTHDAY  DATE,

SEX Char (1),

constraint ck_ch_sex check (Sex IN ('N', 'V')),

constraint pk_id primary key (id)

);

Use Adox :: CatalogPTR to create an MDB file:

HRESULT HR = S_OK;

// set activeConnection of catalog to this stringcstring strincnn (_t ("provider = microsoft.jet.Oledb.4.0; data source = d: //test.mdb"))));

Try {Adox :: _ CatalogPtr M_PCATALOG = NULL; HR = m_pcatalog.createInstance (__ uuidof (adox :: catalog);

Failed (HR))

 {

_com_issue_error (hr);

}

ELSE

 {M_pcatalog-> create (_BSTR_T (STRCNN)); // CREATE MDB

}}} catch (_COM_ERROR & E) { // Notify the user of errors if any. AFXMESSAGEBOX (_T ("error"));}

Create a connection object Open the MDB file just established:

_CONNECTIONPTR g_pconn;

g_pconn.createinstance (__ uuidof (connection));

g_pconn-> open ("provider = microsoft.jet.Oledb.4.0; data source = d: //test.mdb;",  "," ", adConnectunSpecified;

The following functions are used to perform SQL statements in the SQL file:

// function name: Runsqlscript // DESCRIPTION : Perform SQL scripts, peckermen@163.com, 2003-09-15 // Return Type: BOOL Success Return true // argument: LPCSTR SQLScriptFile SQL Script file name // argument : CHAR SEPARATOR SQL segment symbol, default ';' // argument: char remark SQL Note symbol, default '-'bool runsqlscript (lpcstr sqlscriptfile, char separator ='; ', char remark =' - ' ) {BOOL BRET = false; cfilefind Finder; cstract errlong; if (Finder.FindFile (SqlscriptFile) == true) {CFile FSQL; tchar * buffer, * psql, * p; FSQL.Open (Sqlscriptfile, CFILE & :: ModeRead; UINT NFILENGTH = fsql.getlength (); BUFFER = (tchar *) Malloc (nfilelength 1) * sizeof (tchar)); _tcsnset (buffer, tchar ('/ 0'), NfileLength 1); Uint nbytesread = fsql.read (buffer, nfilelength); // read the contents of the SQL file into the memory buffer FSQL.Close ();

P = psql = buffer; Bool brunok = false; Bool binnote = false; Bool bskip = false; cstring strsql; tchar ch; rlog = _t ("); WHILE (p <(buffer NfileLength)) { // Judgment is a note line  IF (binnote)  {IF (* p == tchar ('/ x0a'))  binnote = false;}  ELSE  {IF ((* p == remark) && (* (p 1) == remark)  { binnote = true;  p ; } ELSE {  // Judgment is whether it is a SQL statement end flag  if (* p == separator) {STRSQL = _t ("); BSKIP = false; WHILE (PSQL

TRY { g_pconn-> cursorLocation = aduseclient;  g_pconn-> execute (_BSTR_T (LPCTSTSTSTSTSTSQL), & VRecords, adexecutenorecords;  m_nrecordsaffected = VRecords.ival;   brunok = true; } catch (_COM_ERROR & E)  { brunok = false;}  (brunok)  errlog = errlog _t ("/ n-- successed! / n"); ELSE {{ errlog = errlog _t ("/ n - failed! / n");  break;  } } } }  p ; } free (buffer); BRET = Brunok;} Return Bret;}

Call RunSQLScript to create a table in the Access database:

Runsqlscript (_T ("D: //test.sql")); turn off database connection:

g_pconn-> close ();

:: Couninitialize ();

The above code demonstrates how to use ADO to dynamically create an Access database according to SQL files, welcome to correct.

转载请注明原文地址:https://www.9cbs.com/read-48148.html

New Post(0)