Backendless:删除另一个表中的相关行时删除第一个表中的行

时间:2015-03-11 10:18:56

标签: ios backendless

我有两张桌子。 UserFavourites和Action。 UserFavourites将Action作为其属性(列)。我希望系统在Action表中删除相关的Action时删除UserFavourite行。目前,当我在Action表中删除一行,即UserFavourites的子行时,UserFavourites的Action列为空列,但不会按照我的意愿删除。 非常感谢你!

修改 我以为我会加载相关的UserFavourites对象并将其删除如下:

  ActionCreation* uf = [self.myActions objectAtIndex:self.selectedIndex.row];
    BackendlessDataQuery *query = [BackendlessDataQuery query];
            Fault *fault=nil;
            query.whereClause = [NSString stringWithFormat:@"favouriteAction.objectId =\'%@\'", [uf objectId]];
    @try{
                BackendlessCollection* relatedUserFavourites =[backendless.persistenceService load:uf relations:@[@"*"]error:&fault];

//code for delteing from backendless
            }@catch (Fault *fault) {

                NSLog(@"FAULT = %@ <%@>", fault.message, fault.detail);

            }

但是我得到了例外:

-[ActionCreation allKeys]: unrecognized selector sent to instance 0x7fa8b0fc59c0
2015-03-11 19:57:03.157 ActionPlusChetech[1468:76482] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[ActionCreation allKeys]: unrecognized selector sent to instance 0x7fa8b0fc59c0'
*** First throw call stack:
(
    0   CoreFoundation                      0x000000010c476a75 __exceptionPreprocess + 165
    1   libobjc.A.dylib                     0x000000010c10fbb7 objc_exception_throw + 45
    2   CoreFoundation                      0x000000010c47dd1d -[NSObject(NSObject) doesNotRecognizeSelector:] + 205
    3   CoreFoundation                      0x000000010c3d59dc ___forwarding___ + 988
    4   CoreFoundation                      0x000000010c3d5578 _CF_forwarding_prep_0 + 120
    5   ActionPlusChetech                   0x00000001098322a2 -[PersistenceService load:relations:] + 331
    6   ActionPlusChetech                   0x0000000109830ed7 -[PersistenceService load:relations:error:] + 30
    7   ActionPlusChetech                   0x00000001097f4bb7 -[MyActionsVC deleteButtonTapped] + 1767
    8   ActionPlusChetech                   0x00000001097f66be -[MyActionsVC pushMenuItem:] + 526
    9   Foundation                          0x000000010a611e3a -[NSObject(NSThreadPerformAdditions) performSelector:onThread:withObject:waitUntilDone:modes:] + 900
    10  Foundation                          0x000000010a611971 -[NSObject(NSThreadPerformAdditions) performSelectorOnMainThread:withObject:waitUntilDone:] + 132
    11  ActionPlusChetech                   0x00000001097f750d -[KxMenuItem performAction] + 157
    12  ActionPlusChetech                   0x00000001097f9940 -[KxMenuView performAction:] + 208
    13  UIKit                               0x000000010abc9a22 -[UIApplication sendAction:to:from:forEvent:] + 75
    14  UIKit                               0x000000010acd0e50 -[UIControl _sendActionsForEvents:withEvent:] + 467
    15  UIKit                               0x000000010acd021f -[UIControl touchesEnded:withEvent:] + 522
    16  UIKit                               0x000000010af77e80 _UIGestureRecognizerUpdate + 9487
    17  UIKit                               0x000000010ac0f856 -[UIWindow _sendGesturesForEvent:] + 1041
    18  UIKit                               0x000000010ac10483 -[UIWindow sendEvent:] + 667
    19  UIKit                               0x000000010abdcfb1 -[UIApplication sendEvent:] + 246
    20  UIKit                               0x000000010abea227 _UIApplicationHandleEventFromQueueEvent + 17700
    21  UIKit                               0x000000010abc523c _UIApplicationHandleEventQueue + 2066
    22  CoreFoundation                      0x000000010c3abc91 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17
    23  CoreFoundation                      0x000000010c3a1b5d __CFRunLoopDoSources0 + 269
    24  CoreFoundation                      0x000000010c3a1194 __CFRunLoopRun + 868
    25  CoreFoundation                      0x000000010c3a0bc6 CFRunLoopRunSpecific + 470
    26  GraphicsServices                    0x000000010ef49a58 GSEventRunModal + 161
    27  UIKit                               0x000000010abc8580 UIApplicationMain + 1282
    28  ActionPlusChetech                   0x00000001097ea9e3 main + 115
    29  libdyld.dylib                       0x000000010d106145 start + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
(lldb) 

我真的不明白这个错误。 -[ActionCreation allKeys]:与taht有什么关系?而且没有捕获Backendless异常。 谢谢。

1 个答案:

答案 0 :(得分:0)

好吧,我找到了解决方法。不完全是我想要的,但它确实有效。由于UserFavourites在删除相关的Action对象后具有空列,因此我的应用程序会抛出异常,因为它获取的值为null。所以我决定,每次用户加载他的收藏夹时,检查Action列是否为空,如果是 - 他们发送删除UserFavourites对象的请求。很遗憾我无法找到一种方法来使这两列可以像SQL一样可靠,例如ON UPDATE,ON DELETE等等。但是,嘿,它有效!)希望如果有人遇到这个问题,这将有所帮助。