当前位置: 首页>>代码示例>>C++>>正文


C++ CppSQLite3DB::create方法代码示例

本文整理汇总了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;
				}
			}
		}
	}
开发者ID:chunteck,项目名称:base,代码行数:62,代码来源:DatabaseManager.cpp


注:本文中的CppSQLite3DB::create方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。