使用sqlite3_exec查询数据条数
时间: 2024-03-02 20:52:09 浏览: 68
可以使用如下SQL语句查询表中的总行数:
```
SELECT COUNT(*) FROM table_name;
```
其中,table_name为要查询的表名。
在使用sqlite3_exec函数时,可以将上述SQL语句作为参数传入sqlite3_exec函数,然后在回调函数中处理查询结果。
下面是一个示例代码:
```c
int callback(void *data, int argc, char **argv, char **azColName){
int i;
for(i = 0; i<argc; i++){
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
return 0;
}
int main(int argc, char* argv[])
{
sqlite3 *db;
char *zErrMsg = 0;
int rc;
char *sql;
/* 打开数据库 */
rc = sqlite3_open("test.db", &db);
if( rc ){
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
return 0;
}
/* 查询表中的总行数 */
sql = "SELECT COUNT(*) FROM table_name;";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
if( rc != SQLITE_OK ){
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
/* 关闭数据库 */
sqlite3_close(db);
return 0;
}
```
其中,callback函数用于处理查询结果,在这里只是简单地将结果输出到控制台。需要注意的是,这里的查询结果只有一行一列,即总行数。
阅读全文