[objective-c] الكاكاو البيانات الأساسية وسيلة فعالة لحساب الكيانات


Answers

لكي تكون واضحًا ، فأنت لا تحسب الكيانات ، ولكن في حالات كيان معين. (لحساب عدد الوحدات فعليًا ، اطلب نموذج الكائن المُدار لعدد وحداتها).

لحساب جميع مثيلات كيان معين دون جلب جميع البيانات ، استخدم -countForFetchRequest:

فمثلا:

NSFetchRequest *request = [[NSFetchRequest alloc] init];
[request setEntity: [NSEntityDescription entityForName: entityName inManagedObjectContext: context]];

NSError *error = nil;
NSUInteger count = [context countForFetchRequest: request error: &error];

[request release];

return count;
Question

لقد قرأت الكثير عن Core Data .. ولكن ما هي الطريقة الفعالة لعمل عدد من نوع Entity-Type (مثل ما يمكن لـ SQL فعله مع عدد SELECT (1) ...). الآن أنا فقط حل هذه المهمة مع اختيار كل مع NSFetchedResultsController والحصول على عدد من NSArray ! أنا متأكد من أن هذه ليست الطريقة المثلى ...




إذا كنت تريد العثور على حساب لجلب معين ، أعتقد أن هذه هي أفضل طريقة:

NSError *err;
NSUInteger count = [context countForFetchRequest:fetch error:&err];

if(count > 0) {
NSLog(@"EXIST"); 
} else {
NSLog(@"NOT exist");
}



كتبت طريقة فائدة بسيطة لـ Swift 3 لجلب عدد الكائنات.

static func fetchCountFor(entityName: String, predicate: NSPredicate, onMoc moc: NSManagedObjectContext) -> Int {

    var count: Int = 0

    moc.performAndWait {

        let fetchRequest: NSFetchRequest<NSFetchRequestResult> = NSFetchRequest(entityName: entityName)
        fetchRequest.predicate = predicate
        fetchRequest.resultType = NSFetchRequestResultType.countResultType

        do {
            count = try moc.count(for: fetchRequest)
        } catch {
            //Assert or handle exception gracefully
        }

    }

    return count
}



سريع

من السهل نسبياً الحصول على إجمالي عدد حالات الكيان في Core Data:

let context = (UIApplication.sharedApplication().delegate as! AppDelegate).managedObjectContext
let fetchRequest = NSFetchRequest(entityName: "MyEntity")
let count = context.countForFetchRequest(fetchRequest, error: nil)

اختبرت هذا في جهاز محاكاة مع عدد وجوه 400،000+ والنتيجة كانت سريعة إلى حد ما (وإن لم تكن لحظية).




Related