Post

Replies

Boosts

Views

Activity

Reply to Json Batch insertion: Corrected sample from WWDC19 needed
I got it to work.There are some spelling mistakes on the presentation.The objects you pass in need to have the type [[String : Any]]So you basically have have key value pairs in a list. The strings must match the attribute names in your core data model.Also you need to cast the insertResult to NSBatchInsertResult. Not NSBatchInsertRequest.I used an example entity CDTest with the attributes "id" of type Int32 and "name" of type string. I made "id" the constraint.The following code worked for me then:class ViewController: UIViewController { override func viewDidLoad() { super.viewDidLoad() self.batchInsertExamples() } func batchInsertExamples() { var objectsToInsert: [[String : Any]] = [] for i in 0...5 { objectsToInsert.append(["id" : i, "name" : "My Name"]) } self.persistentContainer.viewContext.performAndWait { do { let insertRequest = NSBatchInsertRequest(entity: CDTest.entity(), objects: objectsToInsert) let insertResult = try self.persistentContainer.viewContext.execute(insertRequest) as! NSBatchInsertResult let success = insertResult.result as! Bool if !success { print("batch insert was not successful") } } catch { print(error.localizedDescription) } if self.persistentContainer.viewContext.hasChanges { do { try self.persistentContainer.viewContext.save() } catch { print("Error: \(error)\nCould not save Core Data context.") return } } } } lazy var persistentContainer: NSPersistentContainer = { let container = NSPersistentContainer(name: "nsbatchinsert") container.loadPersistentStores(completionHandler: { (storeDescription, error) in if let error = error as NSError? { fatalError("Unresolved error \(error), \(error.userInfo)") } container.viewContext.automaticallyMergesChangesFromParent = true container.viewContext.mergePolicy = NSMergeByPropertyObjectTrumpMergePolicy container.viewContext.undoManager = nil container.viewContext.shouldDeleteInaccessibleFaults = true }) return container }() }
Apr ’20
Reply to search array of HKQuantitySample (steps taken) with predicate for NSDates
You are checking against a certain date with time. There most likely is no set of data for that moment. You should use a date range. So something like "startDate > %@ AND startDate < %@".Also check out this function in HKQuery. That's basically what you wantopen class func predicateForSamples(withStart startDate: Date?, end endDate: Date?, options: HKQueryOptions = []) -> NSPredicate
Apr ’20
Reply to search array of HKQuantitySample (steps taken) with predicate for NSDates
Well a certain date is also a date range. Let’s say you want everything on the 18th of April 2020, then you check against >= 18th of April at 00:00 and < 19th of April at 00:00. You can also use smaller ranges, like hours or minutes. I don’t think it makes any sense to go even smaller than minutes. Your taken steps are saved with date and time. If you just check for "date == 18th of April” there will still be some time where you probably won’t have any data for.
Apr ’20
Reply to Case insensitive Entity constraints in Core Data
You could just add a 'name_lowercased' attribute to your data model and make this your unique constraint instead. You can fill your object property with your 'name' and a .lowercased() call then.After all the name "aPpleS" is different from "Apples".If you really don't want that, there also is the option to implement your own MergePolicy, but that seems to be too much for your case.
Apr ’20
Reply to UITableView sometimes not updating
Is your function "reloadTableData()" called if you search?In general I would not check in every function if user is filtering and then access different lists.I would always use self.filteredSectionCustomers and make sure, that if there is nothing in the search field, to simply copy your self.sectionCustomers to self.filteredSectionCustomers. This way self.filteredSectionCustomers is always correct filled. If you change self.filteredSectionCustomers you will also have to reload your tableview
Apr ’20
Reply to search array of HKQuantitySample (steps taken) with predicate for NSDates
If you are comparing against > previous day and < next day, it's perfectly correct to show the total of today and previous day. Because it includes the times. if your previous day is set to 0:00 and you check against > 0:00 then 0:01 already qualifies. Thats still data for yesterday, but thats what you asked for in your predicate. Please see my previous answer again. You first need to start of the day for today. Then startDate needs to be bigger or equal to that and smaller to start of next day. So if you want everything for today, you need:today at 00:00 <= startDate < tomorrow at 00:00
Apr ’20
Reply to querying steps data without stopping query
Sorry, I have no experience with obj c."The way i plan to implement is to just observe if there are any changes. If there are then run the original query to retrieve those changes."That's exactly what HKObserverQuery does. See documentation: https://developer.apple.com/documentation/healthkit/hkobserverquery/executing_observer_queries-> "The observer query’s update handler does not receive any information about the change—just that a change occurred. You must execute another query, for example an HKSampleQuery or HKAnchoredObjectQuery, to access the changes."
Apr ’20