问题描述
这是一个使用sqliteModernCpp库连接到sqlite数据库的C ++ 11程序。有以下类,表示该数据库中的记录(至少是头文件):
#ifndef MOVIE_H
#define MOVIE_H
#include<string>
class movie
{
public:
movie(int id,std::string title,int year,int length);
int get_id() const;
void set_id(int id);
std::string get_title() const;
void set_title(std::string title);
int get_year() const;
void set_year(int year);
int get_length() const;
void set_length(int length);
private:
int id;
std::string title;
int year;
int length;
};
#endif // MOVIE_H
在程序的主要功能中,通过“ id”字段查询数据库以检索记录。请注意,数据库中的该字段是PK,NN和AI,因此此查询将只检索一条记录。当前,它仅使用lambda将数据打印到控制台。如何通过该查询返回movie
类型的对象?
int main()
{
// connect to the database
sqlite::database db("database.db");
// retrieve a record by ID
auto id = 1;
db << "SELECT * FROM movies WHERE rowid = " + std::to_string(id) >> [&](int rowid,int length)
{
std::cout << title;
};
return 0;
}
解决方法
这似乎太容易了,因为您已经解决了困难的部分(未经测试的代码)
auto id = 1;
movie idmovie
db << "SELECT * FROM movies WHERE rowid = " + std::to_string(id) >> [&](int rowid,std::string title,int year,int length)
{
idMovie = { rowid,title,year,length };
};
您也许可以将其缩短为
auto id = 1;
movie idmovie = db << "SELECT * FROM movies WHERE rowid = " + std::to_string(id) >> [&](int rowid,int length) -> movie
{
return { rowid,length };
};
但是我还没有测试其中的错误:)