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


C++ DB::execQuery方法代码示例

本文整理汇总了C++中DB::execQuery方法的典型用法代码示例。如果您正苦于以下问题:C++ DB::execQuery方法的具体用法?C++ DB::execQuery怎么用?C++ DB::execQuery使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在DB的用法示例。


在下文中一共展示了DB::execQuery方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: Exception

		optional<size_t> TimetableRowTableSync::GetMaxRank( util::RegistryKeyType timetableId )
		{
			DB* db = DBModule::GetDB();

			stringstream query;

			// Content
			query
				<< "SELECT MAX(" << COL_RANK << ") AS mr "
				<< " FROM " << TABLE.NAME
				<< " WHERE " << COL_TIMETABLE_ID << "=" << timetableId
			;

			try
			{
				DBResultSPtr rows = db->execQuery(query.str());
				while (rows->next ())
				{
					return rows->getOptionalUnsignedInt("mr");
				}
				return optional<size_t>();
			}
			catch(DBException& e)
			{
				throw Exception(e.getMessage());
			}
		}
开发者ID:Tisseo,项目名称:synthese,代码行数:27,代码来源:TimetableRowTableSync.cpp

示例2: _InitAutoIncrement

				static void _InitAutoIncrement()
				{
					if (!K::TABLE.HAS_AUTO_INCREMENT)
						return;

					try
					{
						DB* db = DBModule::GetDB();
						std::stringstream query;
						query <<
							"SELECT " << 0x00000000FFFFFFFFLL <<
							" & " << TABLE_COL_ID << " AS maxid FROM " << K::TABLE.NAME <<
							" WHERE " << TABLE_COL_ID << ">=" << encodeUId(0) << " AND " <<
							TABLE_COL_ID << "<=" << encodeUId(0xFFFFFFFF) <<
							" ORDER BY " << TABLE_COL_ID << " DESC LIMIT 1"
						;

						DBResultSPtr result (db->execQuery(query.str()));
						if (result->next ())
						{
							util::RegistryKeyType maxid = result->getLongLong("maxid");
							if (maxid > 0)
							{
								_autoIncrementValue = util::decodeObjectId(maxid) + 1;
								util::Log::GetInstance().debug("Auto-increment of table "+ K::TABLE.NAME +" initialized at "+ boost::lexical_cast<std::string>(_autoIncrementValue));
							}
						}

					}
					catch (DBException& e)
					{
						util::Log::GetInstance().debug("Table "+ K::TABLE.NAME +" without preceding id.", e);

					}
					catch (...)
					{
						//					Log::GetInstance().debug("Table "+ getTableName() +" without preceding id.", e);
					}
				}
开发者ID:Tisseo,项目名称:synthese,代码行数:39,代码来源:DBTableSyncTemplate.hpp


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