RAD Studio VCL Reference
|
Specifies the connection information for the data store.
property ConnectionString: WideString;
__property BSTR ConnectionString;
Set ConnectionString to specify the information needed to connect the ADO connection component to the data store. The value used for ConnectionString consists of one or more arguments ADO uses to establish the connection. Specify multiple arguments as a list with individual arguments separated by semicolons.
ADOConnection1.ConnectionString := 'Provider=ProviderRef;Remote Server=ServerRef';
ADOConnection1->ConnectionString = "Provider=ProviderRef;Remote Server=ServerRef";
At design-time, select from the list of available ADO database connections invoked from the Object Inspector.
A connection string may be saved to file for later use. Specify only the name of such a file in ConnectionString to reuse a saved connection string.
The connection string may also contain login information such as user ID and password, for automated logins.
When explicitly passing login information through either the Open method or the ConnectionString, the LoginPrompt property should be set to false to prevent an unnecessary login dialog.
ADO supports the following four arguments for connection strings. Any other arguments (such as a user ID and password) are not processed by ADO and simply passed on to the provider.
C++ Examples:
// //This example demostrates the use of ADO for database conectivity. //Example assumes that a TDBGrid is placed on the form. // void __fastcall TForm2::FormCreate(TObject *Sender) { /* Login details */ String UserName = "db_user_name"; String PassWord = "db_pass_word"; String Server = "my.db.server"; /* Connection String */ String ConnString = "Provider=SQLOLEDB.1;Persist Security Info=False;"; ConnString += "User ID=%s;Password=%s;Data Source=%s;Use Procedure for Prepare=1;"; ConnString += "Auto Translate=True;Packet Size=4096;Use Encryption for Data=False;"; ConnString += "Tag with column collation when possible=False"; /* SQL Query */ String SQLStr = "SELECT * FROM customer WHERE customer_id = :AnId;"; /* All ADO variables */ TADOConnection* ADOConn; TADOQuery* ADOQuery; TDataSource* DataSrc; TParameter* Param; /* Create an ADO connection */ ADOConn = new TADOConnection(this); /* Setup the connection string */ ADOConn->ConnectionString = Format(ConnString, ARRAYOFCONST((UserName, PassWord, Server))); /* Disable login prompt */ ADOConn->LoginPrompt = False; try { ADOConn->Connected = true; } catch (EADOError *e) { MessageDlg("Error while connecting", mtError, TMsgDlgButtons() << mbOK, 0); return; } /* Create the query */ ADOQuery = new TADOQuery(this); ADOQuery->Connection = ADOConn; ADOQuery->SQL->Add(SQLStr); /* Update the parameter that was parsed from the SQL query: AnId */ Param = ADOQuery->Parameters->ParamByName("AnId"); Param->DataType = ftInteger; Param->Value = 1; /* Set the query to Prepared - will improve performance */ ADOQuery->Prepared = true; try { ADOQuery->Active = true; } catch (EADOError *e) { MessageDlg("Error while connecting", mtError, TMsgDlgButtons() << mbOK, 0); return; } /* Create the data source */ DataSrc = new TDataSource(this); DataSrc->DataSet = ADOQuery; DataSrc->Enabled = true; /* Finally initilalize the grid */ DBGrid1->DataSource = DataSrc; }
Delphi Examples:
{ This example demostrates the use of ADO for database conectivity. Example assumes that a TDBGrid is placed on the form. } procedure TForm2.FormCreate(Sender: TObject); const { Connection string } ConnString = 'Provider=SQLOLEDB.1;Persist Security Info=False;' + 'User ID=%s;Password=%s;Data Source=%s;Use Procedure for Prepare=1;' + 'Auto Translate=True;Packet Size=4096;Use Encryption for Data=False;'+ 'Tag with column collation when possible=False'; { SQL Query } SQLStr = 'SELECT * FROM customer WHERE customer_id = :AnId;'; { User access } UserName = 'db_user_name'; PassWord = 'db_pass_word'; Server = 'my.db.server'; var ADOConn : TADOConnection; ADOQuery : TADOQuery; DataSrc : TDataSource; Param : TParameter; begin { Create an ADO connection } ADOConn := TADOConnection.Create(Self); { Setup the provider engine } { Setup the connection string } ADOConn.ConnectionString := Format(ConnString, [UserName, PassWord, Server]); { Disable login prompt } ADOConn.LoginPrompt := False; try ADOConn.Connected := True; except on e: EADOError do begin MessageDlg('Error while connecting', mtError, [mbOK], 0); Exit; end; end; { Create the query } ADOQuery := TADOQuery.Create(Self); ADOQuery.Connection := ADOConn; ADOQuery.SQL.Add(SQLStr); { Update the parameter that was parsed from the SQL query: AnId } Param := ADOQuery.Parameters.ParamByName('AnId'); Param.DataType := ftInteger; Param.Value := 1; { Set the query to Prepared - will improve performance } ADOQuery.Prepared := true; try ADOQuery.Active := True; except on e: EADOError do begin MessageDlg('Error while doing query', mtError, [mbOK], 0); Exit; end; end; { Create the data source } DataSrc := TDataSource.Create(Self); DataSrc.DataSet := ADOQuery; DataSrc.Enabled := true; { Finally initilalize the grid } DBGrid1.DataSource := DataSrc; end;
Copyright(C) 2009 Embarcadero Technologies, Inc. All Rights Reserved.
|
What do you think about this topic? Send feedback!
|