微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从Sqlite数据库的检索行中创建对象

如何解决从Sqlite数据库的检索行中创建对象

这是一个使用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 };
};

但是我还没有测试其中的错误:)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。