2015-02-05 6 views
0

응용 프로그램을 쓰고 서버에서 클라이언트로 연락처를 동기화합니다. 하지만 문제가 생기면 서버에서 클라이언트로 모든 접촉을 얻습니다. 연락처를 몇 개 저장하면 응용 프로그램 오류가 발생합니다.IOS 쿼리에 대한 문을 컴파일 할 수 없습니다.

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; 
} 

AddContact

//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); 
} 
+0

가 나는 완전히 당신에게 대신 순수 SQL 라이트 쿼리의 핵심 데이터를 추천 할 것입니다 Enjoy..coding

. –

+0

나를 인도 할 수 있습니까? – Takeshi

+0

확실히, [공식 문서] (https://developer.apple.com/library/mac/documentation/Cocoa/Conceptual/CoreData/cdProgrammingGuide.html) –

답변

0

오늘도 같은 오류가있어 주소록에 액세스 할 수 없다는 사실이 밝혀졌습니다.

1

메모리 문제가있는 것 같습니다. autorelease 블록에 코드를 넣으십시오.

autoreleasepool 
({() ->() in 
    // code    
})