MySQL++简介

http://blog.csdn.net/whuqin/article/details/7757841


Mysql++是官方发布的、一个为MySQL设计的C++语言的API。Mysql++为Mysql的C-Api的再次封装,它用STL(Standard Template Language)开发并编写,并为C++开发者提供像操作STL容器一样方便的操作数据库的一套机制。其官方API介绍:MySQL++ Reference Manual

与JDBC一样,先建立连接Connection,创建Query,执行操作获得结果。

SimpleResult Query::store()进行更新、删除、创建等操作,SimpleResult代表执行状态,查询是否成功、影响了多少行。

StoreQueryResult Query::store():最常用。StoreQueryResult继承vector<mysqlpp::Row>,Row类似于vector<string>,表示一行中各列的数据。使用可以result[1][4]或result[2]["price"]。

UseQueryResult Query::use(),大结果查询,UserQueryResult是iterator,一次只能获得一个行结果,不停地next直到结束为止。

简单示例

[cpp]  view plain copy
  1. #include <mysql++.h>  
  2. // Connect to the sample database.  
  3. mysqlpp::Connection conn(false);  
  4. if (conn.connect(db, server, user, pass)) {  
  5.     // Retrieve a subset of the sample stock table set up by resetdb  
  6.     // and display it.  
  7.     mysqlpp::Query query = conn.query("select item from stock");  
  8.     if (mysqlpp::StoreQueryResult res = query.store()) {  
  9.        cout << "We have:" << endl;  
  10.        for (size_t i = 0; i < res.num_rows(); ++i) {  
  11.             cout << '\t' << res[i][0] << endl;  
  12.          }  
  13.      }  
  14.      else {  
  15.         cerr << "Failed to get item list: " << query.error() << endl;  
  16.         return 1;  
  17.      }  
  18.      return 0;  
  19. }  
  20. else {  
  21.     cerr << "DB connection failed: " << conn.error() << endl;  
  22.     return 1;  
  23. }  

对查询结果的处理

[cpp]  view plain copy
  1. #include <boost/lexical_cast.hpp>  
  2. #include <mysql++.h>  
  3. lexical_cast<long> ((mysqlpp::Null<string, mysqlpp::NullIsZero>)field)  
  4. lexical_cast<int> ((mysqlpp::Null<string, mysqlpp::NullIsZero>)field)  
  5. lexical_cast<short> ((mysqlpp::Null<string, mysqlpp::NullIsZero>)field)  
  6. lexical_cast<double> ((mysqlpp::Null<string, mysqlpp::NullIsZero>)field)  
  7. lexical_cast<std::string> ((mysqlpp::Null<string, mysqlpp::NullIsBlank>)field)  

你可能感兴趣的:(MySQL++简介)