cocos2d-x 3.0rc2中读取sqlite文件

cocos2d-x 3.0rc2中读取sqlite文件的方式,在Android中直接读取软件内的会失败。须要复制到可写的路径下


sqlite3* dbFile = NULL;

std::string path;

    path = FileUtils::getInstance()->fullPathForFilename("db1.db");
    
#if CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID
    path  = FileUtils::getInstance()->getWritablePath();
    path  += "/db1.db";
    
    FILE* file = fopen(path.c_str(), "r");
    if (file == nullptr)
    {
        ssize_t size;
        const char* data = (char*) FileUtils::getInstance()->getFileData("db1.db", "rb", &size);
        file = fopen(path.c_str(), "wb");
        fwrite(data, size, 1, file);
        CC_SAFE_DELETE_ARRAY(data);
    }
    fclose(file);
    
#endif

CCLOG("数据库路径:%s", path.c_str());
int resultOK = sqlite3_open(path.c_str(), &dbFile);

if (resultOK != SQLITE_OK) {
    sqlite3_close(dbFile);
    CCLOG("数据库打开失败: %d", resultOK);
    return;
}


posted @   mfrbuaa  阅读(329)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示