⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mfc_ex.cpp

📁 MySql C++ library
💻 CPP
字号:
// MFC_ex.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include "MFC_ex.h"

#include <iostream>
#include <iomanip>
#include <mysql++>

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// The one and only application object

CWinApp theApp;

using namespace std;

int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{
	int nRetCode = 0;

	// initialize MFC and print and error on failure
	if (!AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0))
	{
		// TODO: change error code to suit your needs
		cerr << _T("Fatal Error: MFC initialization failed") << endl;
		nRetCode = 1;
	}
	else
	{
		// TODO: code your application's behavior here.

    // The full format for the Connection constructor is
    // Connection(cchar *db, cchar *host="", 
    //            cchar *user="", cchar *passwd="") 
    // You may need to specify some of them if the database is not on
    // the local machine or you database username is not the same as your
    // login name, etc..
    try {
  		Connection con("mysql_cpp_data");
  		Query query = con.query();
  		// This creates a query object that is bound to con.
  
  		query << "select * from stock";
  		// You can write to the query object like you would any other ostrem
  
  		Result res = query.store();
  		// Query::store() executes the query and returns the results
  
  		cout << "Query: " << query.preview() << endl;
  		// Query::preview() simply returns a string with the current query
  		// string in it.
  
  		cout << "Records Found: " << res.size() << endl << endl;
    
  		Row row;
  		cout.setf(ios::left);
  		cout << setw(17) << "Item" 
  			<< setw(4)  << "Num"
  			<< setw(7)  << "Weight"
  			<< setw(7)  << "Price" 
  			<< "Date" << endl
  			<< endl;
    
  		Result::iterator i;
  		// The Result class has a read-only Random Access Iterator
  		for (i = res.begin(); i != res.end(); i++) {
  			row = *i;
  			cout << setw(17) << row[0] 
  				<< setw(4)  << row[1] 
  				<< setw(7)  << row["weight"]
  				// you can use either the index number or column name when
  				// retrieving the colume data as demonstrated above.
  				<< setw(7)  << row[3]
  				<< row[4] << endl;
  		}
    } catch (BadQuery er){ // handle any connection 
                           // or query errors that may come up
      cerr << "Error: " << er.error <<  endl;
      nRetCode = -1;
  
    } catch (BadConversion er) {
      // we still need to cache bad conversions incase something goes 
      // wrong when the data is converted into stock
      cerr << "Error: Tried to convert \"" << er.data << "\" to a \""
  	 << er.type_name << "\"." << endl;
      nRetCode = -1;
    }

	}

	return nRetCode;
}


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -