开发者

What is the benefit of using sqlite3_data_count() over sqlite3_column_count() in the SQLite C API?

开发者 https://www.devze.com 2022-12-19 09:55 出处:网络
After reading the docs, it seems the the function sqlite3_column_count does all the same, but doesn\'t have the restrictions that sqlite3_da开发者_开发知识库ta_count has.

After reading the docs, it seems the the function sqlite3_column_count does all the same, but doesn't have the restrictions that sqlite3_da开发者_开发知识库ta_count has.

Why would I ever want to use sqlite3_data_count over sqlite3_column_count? thanks!


I've looked up the sources of the two functions:

/*
** Return the number of columns in the result set for the statement pStmt.
*/
SQLITE_API int sqlite3_column_count(sqlite3_stmt *pStmt){
  Vdbe *pVm = (Vdbe *)pStmt;
  return pVm ? pVm->nResColumn : 0;
}

/*
** Return the number of values available from the current row of the
** currently executing statement pStmt.
*/
SQLITE_API int sqlite3_data_count(sqlite3_stmt *pStmt){
  Vdbe *pVm = (Vdbe *)pStmt;
  if( pVm==0 || pVm->pResultSet==0 ) return 0;
  return pVm->nResColumn;
}

Now it is clear what the difference is, so NickD was right.

By the way, the documentation is horrible: "The sqlite3_data_count(P) the number of columns in the of the result set of prepared statement P." That's not even correct English, the comments that come with the function definitions are much better.


sqlite3_data_count returns the number of values (columns) of the currently executing statement. With no results it returns 0.

sqlite3_column_count on the other hand, returns always the number of columns, with or without results.

Which one you'll use depends on whether you must get the number of columns or not.

0

精彩评论

暂无评论...
验证码 换一张
取 消