本文整理汇总了C++中CppSQLite3DB::create方法的典型用法代码示例。如果您正苦于以下问题:C++ CppSQLite3DB::create方法的具体用法?C++ CppSQLite3DB::create怎么用?C++ CppSQLite3DB::create使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CppSQLite3DB
的用法示例。
在下文中一共展示了CppSQLite3DB::create方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: registerDatabaseUnit
void DatabaseManager::registerDatabaseUnit(BaseDatabaseUnitPtr unit)
{
if (unit)
{
CppSQLite3DB * database = unit->getDatabase();
if (database)
{
return;
}
database = new CppSQLite3DB();
const char * encryption = unit->getEncryption();
std::string databasePath = CommonUtil::WtoUtf8(unit->getDatabasePath());
if (!databasePath.empty())
{
bool open = false;
try
{
database->open(databasePath.c_str());
unit->setDatabase(database);
unit->runUpdateStatements();
open = true;
}
catch (CppSQLite3Exception e)
{
LOG_ERR_R(DATABASE_MANAGER_LOG_TAG, _T("Failed to open database, error: %u"), e.errorCode());
LOG_ERR_D_A(DATABASE_MANAGER_LOG_TAG_A, "Message: %s", e.errorMessage());
try
{
boost::filesystem::copy(databasePath, databasePath + ".backup");
boost::filesystem::remove(databasePath);
}
catch (...)
{
}
}
if (!open)
{
try
{
database->create(databasePath.c_str());
unit->setDatabase(database);
unit->runCreateStatements();
open = true;
}
catch (CppSQLite3Exception e)
{
LOG_ERR_R(DATABASE_MANAGER_LOG_TAG, _T("Failed to create database, error: %u"), e.errorCode());
LOG_ERR_D_A(DATABASE_MANAGER_LOG_TAG_A, "Message: %s", e.errorMessage());
}
}
if (!open)
{
delete database;
database = nullptr;
}
}
}
}