iphone-核心数据错误'NSInvalidArgumentException',原因:'谓词的未实现的SQL生成'

时间:2012-05-28 06:45:02

标签: iphone sqlite core-data nsfetchrequest

我是iphone开发的新手。我试图使用iphone核心数据存储一些数据。当我试图保存时,我得到的错误就像。

Detected an attempt to call a symbol in system libraries that is not present on the         
_Unwind_Resume called from function -[NSSQLAdapter    
 _newSelectStatementWithFetchRequest:ignoreInheritance:] in image CoreData.

2012-05-28 12:05:38.179 FYPV1[6460:207] *** Terminating app due to uncaught exception
 'NSInvalidArgumentException', reason: 'Unimplemented SQL generation for predicate 
(surname MATCHES $search_surname)'
*** Call stack at first throw:
(
0   CoreFoundation                      0x02668b99 __exceptionPreprocess + 185
1   libobjc.A.dylib                     0x027b840e objc_exception_throw + 47
2   CoreData                            0x0003be86 -[NSSQLGenerator generateSQLStatementForFetchRequest:ignoreInheritance:countOnly:] + 1254
3   CoreData                            0x0003b6f0 -[NSSQLAdapter _newSelectStatementWithFetchRequest:ignoreInheritance:] + 480
4   CoreData                            0x0003b501 -[NSSQLAdapter newSelectStatementWithFetchRequest:] + 49
5   CoreData                            0x0003b3ae -[NSSQLCore newRowsForFetchPlan:] + 430
6   CoreData                            0x0003ab09 -[NSSQLCore objectsForFetchRequest:inContext:] + 297
7   CoreData                            0x0003a6fe -[NSSQLCore executeRequest:withContext:error:] + 206
8   CoreData                            0x000e891c -[NSPersistentStoreCoordinator executeRequest:withContext:error:] + 1084
9   CoreData                            0x00037897 -[NSManagedObjectContext executeFetchRequest:error:] + 359
10  FYPV1                               0x0000715f -[Contacts saveContacts:] + 367
11  UIKit                               0x001fc7f8 -[UIApplication sendAction:to:from:forEvent:] + 119
12  UIKit                               0x00287de0 -[UIControl sendAction:to:forEvent:] + 67
13  UIKit                               0x0028a262 -[UIControl(Internal) _sendActionsForEvents:withEvent:] + 527
14  UIKit                               0x00288e0f -[UIControl touchesEnded:withEvent:] + 458
15  UIKit                               0x002203d0 -[UIWindow _sendTouchesForEvent:] + 567
16  UIKit                               0x00201cb4 -[UIApplication sendEvent:] + 447
17  UIKit                               0x002069bf _UIApplicationHandleEvent + 7672
18  GraphicsServices                    0x02f48822 PurpleEventCallback + 1550
19  CoreFoundation                      0x02649ff4 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 52
20  CoreFoundation                      0x025aa807 __CFRunLoopDoSource1 + 215
21  CoreFoundation                      0x025a7a93 __CFRunLoopRun + 979
22  CoreFoundation                      0x025a7350 CFRunLoopRunSpecific + 208
23  CoreFoundation                      0x025a7271 CFRunLoopRunInMode + 97
24  GraphicsServices                    0x02f4700c GSEventRunModal + 217
25  GraphicsServices                    0x02f470d1 GSEventRun + 115
26  UIKit                               0x0020aaf2 UIApplicationMain + 1160
27  FYPV1                               0x00001e59 main + 121
28  FYPV1                               0x00001dd5 start + 53
)
terminate called after throwing an instance of 'NSException'

如何解决这个问题。

这是我保存数据的代码。

   NSError *error;  

    NSDictionary *subs = [NSDictionary 
                          dictionaryWithObjectsAndKeys:fetchContact.first_name, @"search_firstname",fetchContact.surname,@"search_surname", nil];

    NSFetchRequest *fetchRequestCheckNil = 
    [managedObjectModel fetchRequestFromTemplateWithName:
     @"Fetchaddcontact" substitutionVariables:subs];

    NSArray *fetchedObjects=[context executeFetchRequest:fetchRequestCheckNil error:nil];
    if ([fetchedObjects count]>0) {
        for (ENTITYADDCONTACTS *contactDetails
             in fetchedObjects) {

            [self updateDBModel:contactDetails];
        }
    }
else {   
    ENTITYADDCONTACTS *contactDetails;
    contactDetails = [NSEntityDescription
                      insertNewObjectForEntityForName:@"ENTITYADDCONTACTS" 
                      inManagedObjectContext:context]; 
    [self updateDBModel:contactDetails];
    }

if (![context save:&error]) {
    NSLog(@"Whoops, couldn't save: %@", [error localizedDescription]);
}

1 个答案:

答案 0 :(得分:1)

根据Predicate Programming Guide约束和限制部分,您不能将MATCHES关键字与sqlite持久存储一起使用。

引用:

  

匹配运算符使用正则表达式,因此Core Data的SQL存储不支持它 - 尽管它可以与内存中过滤一起使用。

在你的情况下,我会使用BEGINSWITH或LIKE。请注意,BEGINSWITH具有性能优势,因此我建议尽可能使用它。

以下是字符串的可用谓词比较:

  

字符串比较默认情况下是变音符号和变音符号敏感的。您可以使用方括号内的关键字符c和d修改运算符,分别指定大小写和变音符号不敏感,例如firstName BEGINSWITH [cd] $ FIRST_NAME。

     

<强> BEGINSWITH

     

左手表达式以右手表达开始。

     

<强>包含

     

左手表达式包含右手表达式。

     

<强>的endsWith

     

左手表达以右手表达结束。

     

<强> LIKE

     

左手表达式等于右手表达式:?和*被允许作为通配符,在哪里?匹配1个字符,*匹配0个或更多个字符。在Mac OS X v10.4中,通配符与换行符不匹配。

     

<强>匹配

     

根据ICU v3,左手表达式使用正则表达式比较等于右手表达式(有关详细信息,请参阅ICU正则表达式用户指南)。

这里的例外是MATCHES,如前所述,它不能与sqlite持久存储一起使用。除此之外,您可以使用plain ==进行严格的相等比较。