我正在尝试将我的一个项目从 Android 移植到 iOS,我遇到了一些一直令人烦恼的基本问题。就像目前一样,我无法调用我创建的方法,因为它似乎不存在,这令人困惑,因为它就在那里。
我不确定我做错了什么。我曾尝试查看一些关于该主题的书籍以及有关该主题的其他问题,但找不到任何可以解释我做错了什么的东西。据我所知,我做得对。
我收到以下警告:
找不到实例方法“-CheckIfTableExists:withDB”(返回类型默认为“id”)
和
接收器类型“int”不是“d”或接口指针,考虑将其转换为“id”
我收集到第二个警告是因为编译器认为它通过将我的返回值更改为“id”而不是“int”来提供帮助,所以我试图将值放入的变量不匹配。但是我不明白为什么它将返回类型从 int 更改为 id 开始,如果返回变量被弄乱了,那么编译器找到了该方法,那么为什么它说它找不到该方法?
有人可以帮忙吗?下面是有问题的代码。
#import "sqlite3.h"
@implementation DatabaseHelper
sqlite3 *db;
NSString *Database_Name = @"UniversalAVDatabase.db";
int Database_Version = 14;
NSString *Database_Table = @"Database";
NSString *Attribute_DB_Version = @"Database_Version";
- (NSString *)filePath
{
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDir = [paths objectAtIndex:0];
return [documentsDir stringByAppendingPathComponent:Database_Name];
}
- (int) CheckIfTableExists:(NSString *) TableName withDB:(sqlite3 *) db
{
NSString *dbQuery = [NSString stringWithFormat:@"SELECT DISTINCT tbl_name FROM sqlite_master WHERE tbl_name = '%@';", TableName];
sqlite3_stmt *SQLStatement;
int Result = sqlite3_prepare_v2(db, [dbQuery UTF8String], -1, &SQLStatement, nil);
return Result;
}
- (void) Initialize
{
int CurrentDatabaseVersion = 1;
//attempt to open the database.
int Result = sqlite3_open([[self filePath] UTF8String], &db);
if (Result == SQLITE_OK)
{
//Check if the Database table exists
int TableDBExists = 1;
[TableDBExists CheckIfTableExists:Database_Table withDB:db]; //I get two warnings from this
if (TableDBExists == 1)
{
//If it exists check the version of the database to see if it is a later version.
//CurrentDatabaseVersion = dbHelper.GetDatabaseVersion(db);
}
if (CurrentDatabaseVersion < Database_Version)
{
//UpgradeDatabase();
}
}
else
{
//If the database does not exist then create it.
}
}
@end