SQLite中备份数据库程序操作方式

    注:备份操作后,目标数据库与源数据库完全一样。

    sqlite3 *pDBSource = NULL;
    sqlite3 *pDBDest = NULL;
    sqlite3_backup *bak;
    int nRet;
    nRet = sqlite3_open(strSourceDBAddr.data(), &pDBSource);   //源数据库
    nRet = sqlite3_open(strDestDBAddr.data(), &pDBDest); //目标数据库

    if (nRet != SQLITE_OK)
    {
        return bFlag;
    }

    bak = sqlite3_backup_init(pDBDest, "main", pDBSource, "main");  //特别注意,源数据库名和目的数据库名都是固定的字符串“main”
    if (bak)
    {
        sqlite3_backup_step(bak, -1);
        sqlite3_backup_finish(bak);

        bFlag = true;
    }

    const char* szError;
    szError = sqlite3_errmsg(pDBDest);  //错误信息查看
    BSLog::writeMessage(szError);

    sqlite3_close(pDBSource);
    sqlite3_close(pDBDest);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值