绑定或列索引超出范围

问题描述

| 我想删除现有sqlite数据库中的所有数据,这是我正在使用的代码:
sqlite3* database;
databaseName = @\"AppDB\";
NSString *pathToDatabase;
NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES);
NSString *documentsDir = [documentPaths objectAtIndex:0];
pathToDatabase = [documentsDir stringByAppendingPathComponent:databaseName];

int databaseReturnCode = sqlite3_open([pathToDatabase UTF8String],&database);
NSLog(@\"databaseReturnCode %d\",databaseReturnCode);
if(databaseReturnCode == SQLITE_OK) {


    const char *sql = \"delete from AppDB\";
    sqlite3_stmt *delete_statement;

    sqlite3_prepare_v2(database,sql,-1,&delete_statement,NULL);

    sqlite3_bind_int(delete_statement,1,1);

    printf( \"error or not an error? :  %s\\n\",sqlite3_errmsg(database) ); 

    sqlite3_reset(delete_statement);

    sqlite3_finalize(delete_statement);

}
sqlite3_close(database);    
此数据库中有多个字段和多个表。请让我知道错误是什么。提前致谢。     

解决方法

请注释此“ 1”行并运行代码,因为在查询中您没有任何需要绑定的参数。我也徘徊这个查询是否存在?您可以直接从someDatabase中删除吗?我认为没有任何查询需要数据库名称! (我希望“ 2”是表名)。 [为了便于理解,我们应该遵循标准的命名约定。] 谢谢     

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...