How to use RecordSets without using the AppWizard at the creation of your project

All the books that I4ve read have the official chapter " Database programming", a little chapter in which there is the typical example of: Create a new project, with App wizard select the option use database and select what database will you use...

Ok, I begin my application, and one month later I realize "mmm...., I need one database for this project", or... " I need to add another Recordset to the database", or... " I need to add another database", must I begin again with my application? The answer is NO, and the solution is easy ( a dummy like me uses it, so it must be easy ;-) ).

Steps to do this:

  • Create a normal project without database support ( or if you have one created use that...).
  • In stdafx.h add this include: #include "afxdb.h"
  • In the class in wich you want to use the database ( for example in the View), add this member variable: CDatabase m_MyDatabase
  • When you init that class ( for example if we use the View in on Initial Update), init your database, calling: m_MyDatabase.Open(NULL,FALSE,FALSE,os) (In wich "os" is only a CString with the parameters to open your database, for example: CString os="ODBC;DSN=MyDb;UID=MyUser;PWD=MyPassword;") In this string we put: ODBC ( using ODBC database)
    • DSN=... -> The name of the datasource ( this is the name that you put when you add to the database the ODBC administrator your database),
    • UID=... -> Is the name of the user of the database,
    • PWD=... -> Is the password of that user.
  • Now we need an special recordset to get the data from our database. This is easy. Create a class ( with AppWizard ( Ctrl+W Key...), Add New Class), that inherits from CRecordSet then select your database and the table that you want to get from that database, and the fields that you need, ( you can create a lot of classes inherited from CRecordSet, as many "views" of your database as you need ( for example one recordset for each table or...).
  • Include the ".h" file of the recordset in the file in wich you are going to use it, and input variables of that recordset class in the classes that you need... CMyRecordSet *MyRecordSet;
  • Then to open the recordSet...:

    MyRecordSet=new CMyRecordSet(m_Database);
    MyRecordSet.Open() // You can open it in many ways, see the help
    .
    .
    .
    MyRecordSet.Close()

  • Don4t forget when you exit from the program to close the database...

And...,If you want to see more things, take a look at the help, this is only the starting point ( made by a dummy... :-) ).



Comments

Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • The enterprise has experienced a data explosion over the past few years that has redefined the possible. In the HP eBook Big Data 20/20, HP experts explore what the future of Big Data and analytics means for that enterprise. The widely varied deluge of data in companies presents both challenges and opportunities to deliver greater value and gain competitive advantage.

  • On-demand Event Event Date: March 19, 2015 The 2015 Enterprise Mobile Application Survey asked 250 mobility professionals what their biggest mobile challenges are, how many employees they are equipping with mobile apps, and their methods for driving value with mobility. Join Dan Woods, Editor and CTO of CITO Research, and Alan Murray, SVP of Products at Apperian, as they break down the results of this survey and discuss how enterprises are using mobile application management and private app stores to …

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date