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


C++ DataTable::rowCount方法代码示例

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


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

示例1: executeSqlInsert

	int SqliteClient::executeSqlInsert(const DataTable& table)
	{
		Locker locker(&_sqliteDbMutex);

		if(table.getName().empty())
			return -1;
		if(table.columnCount() == 0)
			return -2;
		if(table.rowCount() == 0)
			return -3;

		// such like '"INSERT INTO example VALUES (?1, ?2, ?3, ?4, ?5, ?6, ?7)";'
		string valuesStr = "";
		int columnCount = table.columnCount();
		for (int i = 0; i < columnCount; i++)
		{
			if(i != 0)
			{
				valuesStr += ", ";
			}
			valuesStr += Convert::convertStr("?%d", i + 1);
		}
		string sql = Convert::convertStr("INSERT INTO [%s] VALUES (%s)", table.getName().c_str(), valuesStr.c_str());
		sqlite3_stmt *stmt;
		int result = sqlite3_prepare_v2(_sqliteDb, sql.c_str(),  sql.length(), &stmt, 0);  
		if(result != SQLITE_OK)
		{
			printErrorInfo("sqlite3_prepare_v2", sql);
			return result;
		}

		result = execute("BEGIN TRANSACTION");
		if(result != SQLITE_OK)
		{
			return result;
		}
		int rowCount = table.rowCount();
		for (int i = 0; i < rowCount; i++)
		{
			const DataRow* row = table.getRows()->at(i);
			for (int j = 0; j < columnCount; j++)
			{
				const DataCell* cell = row->getCells()->at(j);
				if(cell != NULL)
				{
					ValueTypes type = cell->getType();
					const Value value = cell->getValue();
					switch (type)
					{
					case Null:
						sqlite3_bind_null(stmt, j + 1);
						break;
					case Integer:
						sqlite3_bind_int(stmt, j + 1, value.nValue);
						break;
					case DateTime:
					case String:
						result = sqlite3_bind_text(stmt, j + 1, value.strValue, strlen(value.strValue), SQLITE_TRANSIENT);
						break;
					case Float:
						sqlite3_bind_double(stmt, j + 1, value.dValue);
						break;
					default:
						assert(false);
						break;
					}
				}
			}

			result = sqlite3_step(stmt);
			if (result != SQLITE_DONE)
			{
				printErrorInfo("sqlite3_step", sql);
			}

			result = sqlite3_reset(stmt);
			if(result != SQLITE_OK)
			{
				printErrorInfo("sqlite3_reset", sql);
			}
		}

		result = execute("COMMIT TRANSACTION");
		if(result != SQLITE_OK)
		{
			return result;
		}
		sqlite3_finalize(stmt);
		if(result != SQLITE_OK)
		{
			printErrorInfo("sqlite3_finalize", sql);
			return result;
		}

		return SQLITE_OK;
	}
开发者ID:davidbao,项目名称:SmartTimer,代码行数:96,代码来源:SqliteClient.cpp


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