【问题标题】:Backendless: delete row in 1st table when related row in another table is deletedBackendless:删除另一个表中的相关行时删除第一个表中的行
【发布时间】:2015-03-11 10:18:56
【问题描述】:

我有两张桌子。用户收藏夹和操作。 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 异常。 谢谢。

【问题讨论】:

  • 伙计们,我希望有人能帮助我。我真的不知道该怎么办,也找不到任何相关信息((
  • 由于我的答案被删除,我将其添加为评论:这是我们支持论坛上帖子的副本:support.backendless.com/topic/… 如果在我们的论坛中提出问题,它将成为答案的主要来源。我们不会在多个地方发布答案。我们的支持论坛是获得对 Backendless 支持的重点
  • 嗨,马克,我明白了。我会等到它在支持论坛中得到回答。非常感谢,非常感谢您的帮助。
  • 马克,你能回答一下后端支持论坛的问题吗?我真的需要解决这个问题。感谢您的时间。

标签: ios backendless


【解决方案1】:

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

【讨论】:

    猜你喜欢
    • 2018-10-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-04-26
    • 2014-01-30
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多