【问题标题】:IOS Could not compile statement for queryIOS无法编译查询语句
【发布时间】:2015-02-05 03:02:55
【问题描述】:

我正在编写一个应用程序,将联系人从服务器同步到客户端。但是我有一个问题,我从服务器到客户端的所有联系人,当我保存一些联系人时,应用程序错误。

AB: Could not compile statement for query (ABCCopyArrayOfAllInstancesOfClassInSourceMatchingProperties):
SELECT ROWID, Name, ExternalIdentifier, Type, ConstraintsPath, ExternalModificationTag, ExternalSyncTag, AccountID, Enabled, SyncData, MeIdentifier, Capabilities FROM ABStore WHERE Enabled = ?;

日志

2015-02-05 09:54:26.667 SoftFlowContactSync[5367:475593] Authorized : Cầu Khác
2015-02-05 09:54:27.056 SoftFlowContactSync[5367:475593] Authorized : Hoài
2015-02-05 09:54:27.234 SoftFlowContactSync[5367:475593] Authorized : Tùng
2015-02-05 09:54:27.390 SoftFlowContactSync[5367:475593] Authorized : Hà Duy
2015-02-05 09:54:27.478 SoftFlowContactSync[5367:475593] Authorized : Hữu Ru
....
2015-02-05 09:54:27.617 SoftFlowContactSync[5367:475593] Authorized : Duy Cường
AB: Could not compile statement for query (ABCCopyArrayOfAllInstancesOfClassInSourceMatchingProperties):
SELECT ROWID, Name, ExternalIdentifier, Type, ConstraintsPath, ExternalModificationTag, ExternalSyncTag, AccountID, Enabled, SyncData, MeIdentifier, Capabilities FROM ABStore WHERE Enabled = ?;
SQL error
SQL error
2015-02-05 09:54:37.794 SoftFlowContactSync[5367:475593] Authorized : Dũng
AB: Could not compile statement for query (ABCCopyArrayOfAllInstancesOfClassInSourceMatchingProperties):
SELECT ROWID, Name, ExternalIdentifier, Type, ConstraintsPath, ExternalModificationTag, ExternalSyncTag, AccountID, Enabled, SyncData, MeIdentifier, Capabilities FROM ABStore WHERE Enabled = ?;

我的代码:

同步

-(void)runSyn
{
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^(void){
    self.txtStatus.text = @"Đang đồng bộ...";
sqlite3_stmt *statement = nil;
const char * sqlFind;
sqlFind = "SELECT first, last, phone, email FROM contact";
const char *dbPath = [_dataBasePath UTF8String];
if(sqlite3_open(dbPath,&_DB)==SQLITE_OK)
{
    sqlite3_prepare_v2(_DB, sqlFind, -1, &statement, NULL);
    while (sqlite3_step(statement) == SQLITE_ROW) {
        NSString* txtFirst = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 0)];
        NSString* txtLast = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 1)];
        NSString* txtPhone = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 2)];
        NSString* txtEmail = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 3)];
        [self addContact:txtFirst :txtLast :txtPhone :txtEmail];

    }

    sqlite3_finalize(statement);
}else
{
    [self showUIAlertWithMessage:@"Thất bại trong việc mở dữ liệu!" andTitle:@"Thông báo"];
    NSLog(@"LoadData: %@", @"Thất bại trong việc mở dữ liệu!");

}
sqlite3_close(_DB);
    // update UI on the main thread
    dispatch_async(dispatch_get_main_queue(), ^(void){
        self.txtStatus.text = myDateString;
        NSLog(@"RUNSYNC: %@",@"Da add tat ca contact vao thiet bi.");
    });
});

[[NSURLCache sharedURLCache] removeAllCachedResponses];
aTime = nil;
}

添加联系人

//Thêm contact
-(void) addContact: (NSString*) txtFirst : (NSString*) txtLast : (NSString*) txtNumber : (NSString *)txtEmail
{

if (ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusDenied ||
    ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusRestricted){
    //1
    NSLog(@"Denied");
    UIAlertView *cantAddContactAlert = [[UIAlertView alloc] initWithTitle: @"Không thể thêm được danh bạ!" message: @"Bạn cần cho phép ứng dụng sử dụng danh bạ của máy." delegate:nil cancelButtonTitle: @"Đồng ý" otherButtonTitles: nil];
    [cantAddContactAlert show];
} else if (ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusAuthorized){
    //2
    NSLog(@"Authorized : %@",txtFirst);
    [self Contact:txtFirst:txtLast:txtNumber:txtEmail];
} else
{
    //3
    NSLog(@"Not determined");
    ABAddressBookRequestAccessWithCompletion(ABAddressBookCreateWithOptions(NULL, nil), ^(bool granted, CFErrorRef error) {
        dispatch_async(dispatch_get_main_queue(), ^{
            if (!granted){
                //4
                UIAlertView *cantAddContactAlert = [[UIAlertView alloc] initWithTitle: @"Không thể thêm được danh bạ!" message: @"Bạn cần cho phép ứng dụng sử dụng dạnh bạ của máy." delegate:nil cancelButtonTitle: @"Đồng ý" otherButtonTitles: nil];
                [cantAddContactAlert show];
                return;
            }
            //5
            NSLog(@"Authorized : %@",txtFirst);
            [self Contact:txtFirst:txtLast:txtNumber:txtEmail];
        });
    });
}
}

//Contact
-(void) Contact: (NSString*) txtFirst : (NSString*) txtLast : (NSString*) txtNumber : (NSString*) txtEmail
{
ABAddressBookRef addressBookRef = ABAddressBookCreateWithOptions(NULL, nil);
ABRecordRef pet = ABPersonCreate();
ABRecordSetValue(pet, kABPersonFirstNameProperty, (__bridge CFStringRef)txtFirst, nil);
ABRecordSetValue(pet, kABPersonLastNameProperty, (__bridge CFStringRef)txtLast, nil);
ABMutableMultiValueRef phoneNumbers = ABMultiValueCreateMutable(kABMultiStringPropertyType);
ABMultiValueAddValueAndLabel(phoneNumbers, (__bridge CFStringRef)txtNumber, kABPersonPhoneMainLabel, NULL);
ABRecordSetValue(pet, kABPersonPhoneProperty, phoneNumbers, nil);
ABMutableMultiValueRef multiEmail = ABMultiValueCreateMutable(kABMultiStringPropertyType);
ABMultiValueAddValueAndLabel(multiEmail, (__bridge CFStringRef)txtEmail, kABWorkLabel, NULL);
ABRecordSetValue(pet, kABPersonEmailProperty, multiEmail, nil);
CFRelease(multiEmail);
ABAddressBookAddRecord(addressBookRef, pet, nil);
NSArray *allContacts = (__bridge NSArray *)ABAddressBookCopyArrayOfAllPeople(addressBookRef);
for (id record in allContacts){
    ABRecordRef thisContact = (__bridge ABRecordRef)record;
    if (CFStringCompare(ABRecordCopyCompositeName(thisContact),
                        ABRecordCopyCompositeName(pet), 0) == kCFCompareEqualTo){
        return;
    }
}

ABAddressBookSave(addressBookRef, nil);
}

【问题讨论】:

  • 我完全推荐你使用核心数据而不是纯 sql lite 查询。
  • 当然,检查official documentation
  • 我检查了文档。但我还是不知道为什么。

标签: ios objective-c xcode xcode6 abaddressbook


【解决方案1】:

您似乎遇到了一些内存问题。将您的代码放入自动释放块中。

享受..编码

 autoreleasepool({})

【讨论】:

    【解决方案2】:

    今天遇到同样的错误,原来我没有访问通讯录。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2023-04-06
      • 2011-10-31
      • 1970-01-01
      • 2013-07-29
      • 1970-01-01
      • 2023-04-02
      相关资源
      最近更新 更多