我想创建一个动态向量,每个向量元素都是一个字符串数组。
我想到的数据结构是这样的:
VECTOR:
[0] = [str1, str2, str3]
[1] = [str1, str2, str3]
[2] = [str1, str2, str3]
我正确地在 res 变量中插入了值,但我的代码无法正常工作:打印循环执行 4 次,但每次只打印 LAST 元素。 我认为问题可能是: 1(我没有在向量中正确推送字符串数组; 2(当我想打印它时,我没有正确管理矢量和所有字符串的迭代。
这是我的代码:
std::vector<std::string*> DatabaseConnector::ExecuteQuery(std::string query, std::vector <std::string> columns)
{
std::vector<std::string*> results;
std::string res[columns.size() + 1]; // last value = ' ' to signal end of array
db_params.res = db_params.stmt->executeQuery(query);
while (db_params.res->next()) // Access column data by alias or column name
{
int i = 0;
for(std::string s : columns)
res[i++] = db_params.res->getString(s);
res[i] = " ";
results.push_back(res);
}
for(auto el :results)
{
int i=0;
while(el[i].compare("") != 0)
std::cout << el[i++] << " ";
std::cout << std::endl;
}
return results;
};
std::string res[columns.size() + 1];
是一个可变长度数组,您将指向第一个元素的指针推送到向量中。 您应该使用std::vector<std::string> res;
和std::vector<std::vector<std::string>> results;
std::vector<std::vector<std::string>> DatabaseConnector::ExecuteQuery(std::string query, const std::vector <std::string> &columns)
{
std::vector<std::vector<std::string>> results;
db_params.res = db_params.stmt->executeQuery(query);
while (db_params.res->next()) // Access column data by alias or column name
{
std::vector<std::string> res;
for(std::string s : columns)
res.push_back(db_params.res->getString(s));
results.push_back(res);
}
for(const auto &el :results)
{
for (const auto &res : el)
std::cout << res << " ";
std::cout << std::endl;
}
return results;
}