我使用Soci进行数据库查询。现在我需要一个自定义的resultset类来包装soci :: rowset。我无法让我的代码在下面的方式工作,因为复制构造函数在soci中是私有的(根据源文件不支持)。如何在没有复杂代码的情况下完成包含soci :: rows列表的包装器(特此是对Row的类型定义)?任何关于如何去做的设计或方向都值得赞赏
我的标题文件
typedef soci::row Row;
class ResultSet
{
public:
ResultSet();
~ResultSet();
void Copy(soci::rowset<soci::row>& rs);
Row GetNextRow();
bool HasRows();
private:
soci::rowset<soci::row> m_rows;
soci::rowset_iterator<soci::row> m_iterator;
bool m_isAccessed;//if first access on row is done
};
源文件
ResultSet::ResultSet() {
m_isAccessed=false;
}
ResultSet::~ResultSet() {
}
Row ResultSet::GetNextRow() {
if(m_isAccessed) {
m_iterator++;//increment row
m_isAccessed=true;
}
return *m_iterator;
}
bool ResultSet::HasRows() {
return m_iterator!=m_rows.end();//it have not reached the end yet;
}
void ResultSet::Copy(soci::rowset<soci::row>& rs) {
m_rows = rs;
m_iterator = rs.begin();//put it at row 1
}
以下是我在连接的ExecuteQuery函数中的使用方法。 m_session是soci :: session
void ConnectionMgr::ExecuteQuery(wxString& sql, ResultSet& rs) {
try {
soci::rowset<soci::row> rsInternal = m_session.prepare<<sql.ToStdString();
rs.Copy(rsInternal);
}
catch (std::exception const& e) {
m_error = wxString::Format(wxT("SqlQuery close error:%s\n"), e.what());
}
}
我希望以后如何使用该课程的示例
wxString sql = wxT("-- a query\n SHOW DATABASES;");
ResultSet rs;
m_conn->ExecuteQuery(sql, rs);
while(rs.HasRows())
{
wxString name = wxString(rs.GetNextRow().get<std::string>(0));
//work with name here
}
答案 0 :(得分:0)
因为我使用wxWidgets,所以我决定将数据库层恢复为wxDatabase并将使用它并维护它