Introduction
This article intends to introduce you to using OLE DB for database access. It
does this by showing you how to use OLE DB to insert records into a database and
then read back those records. Before you start there are some things you need to do first, like
creating an MDB file.
Things to do first...
- First create a new MS Access database called test.mdb and create a single
table and call it 'main'.
- Now add two fields to 'main' called 'Name' of type 'Text' and 'Age' of
type 'Number'.
- Copy test.mdb to d:\
Some concepts
In .NET, connections to databases and queries are achieved through data
providers. The OLE DB .NET data provider is implemented through various classes
within the System::Data::OleDb namespace. In this article we only examine three
of these classes - OleDbConnection, OleDbCommand and
OleDbDataReader. The
OleDbConnection object represents a database connection. The OleDbCommand object
wraps an SQL command that is performed on a database connection. When we
are making an INSERT or an UPDATE query on a database table, those two are the
only classes we'll need. But when we are retrieving data from a table, we'll
also need to use the OleDbDataReader class. This class allows us to browse
through a row of records in a forward-only direction.
Inserting records code snippet
OleDbConnection* conn = new OleDbConnection(
"PROVIDER=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\test.mdb");
conn->Open();
OleDbCommand* cmd = new OleDbCommand(sqlstr,conn);
cmd->ExecuteNonQuery();
conn->Close();
Inserting records is the simpler of the two processes. We create a connection
using the OleDbConnection object, create an OleDbCommand
object and associate it with the OleDbConnection object. Now we
call the ExecuteNonQuery method, which will execute the SQL command
we had passed to the OleDbCommand constructor. We then close
the connection.
Reading records code snippet
OleDbConnection* conn = new OleDbConnection(
"PROVIDER=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\test.mdb");
conn->Open();
OleDbCommand* cmd = new OleDbCommand(sqlstr,conn);
OleDbDataReader* rdr = cmd->ExecuteReader();
while (rdr->Read())
{
. . .
. . .
}
conn->Close();
This is basically the same as far as creating the OleDbConnection
and OleDbCommand objects are concerned. But instead of
calling ExecuteNonQuery directly, we call ExecuteReader
which will return a OleDbDataReader object. We can use this
OleDbDataReader object to browse through the recordset. Keep calling
Read
which will return false when it has finished the whole recordset. There are
several ways to read from a recordset but I prefer get_Item which
allows you to specify a field name opposed to other functions like
GetValue which require us to pass the index of the field in the table
which is a bad method in my opinion.
Console::WriteLine(rdr->get_Item("FullName"));
There is a sequel to this article on the use of bound controls with OLE DB
which you can find here.
Revision History
- Jul 04 2002 - Did a full redo of the article, added a sample project and now uses MC++ instead of
C#
- Dec 02 2001 - Changed the program for .Net beta 2.0
Nish is a real nice guy who has been writing code since 1990 when he first got his hands on an 8088 with 640 KB RAM. Originally from sunny Trivandrum in India, he has been living in various places over the past few years and often thinks it’s time he settled down somewhere.
Nish has been a Microsoft Visual C++ MVP since October, 2002 - awfully nice of Microsoft, he thinks. He maintains an MVP tips and tricks web site -
www.voidnish.com where you can find a consolidated list of his articles, writings and ideas on VC++, MFC, .NET and C++/CLI. Oh, and you might want to check out his blog on C++/CLI, MFC, .NET and a lot of other stuff -
blog.voidnish.com.
Nish loves reading Science Fiction, P G Wodehouse and Agatha Christie, and also fancies himself to be a decent writer of sorts. He has authored a romantic comedy
Summer Love and Some more Cricket as well as a programming book –
Extending MFC applications with the .NET Framework.
Nish's latest book
C++/CLI in Action published by Manning Publications is now available for purchase. You can read more about the book on his blog.
Despite his wife's attempts to get him into cooking, his best effort so far has been a badly done omelette. Some day, he hopes to be a good cook, and to cook a tasty dinner for his wife.