How to add an object to SwiftData in Swift
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/83d69/83d69b38bc0ee5b73f663867accefead7c6ab6ca" alt="Three flowers that represent Swift, Swift Data and Xcode. The text "Add an Object to a SwiftData Persistent Container" sits beneath them."
A step by step guide on inserting a new object to a SwiftData persistent storage container using SwiftUI, UIKit or AppKit.
data:image/s3,"s3://crabby-images/944ad/944ad72a676396733294f9afe9321263163bb9cf" alt="A screenshot of an iPhone showing the result of the sample app available on our open source swift GitHub repository."
The following tutorial has been made available, along with a simple app for demonstrating SwiftData, through the tutorial/swift-data-basics branch on our Open Source Swift Starter Project.
git clone git@github.com:delasign/swift-starter-project.git
Step One: Setup the Project
data:image/s3,"s3://crabby-images/7aef8/7aef8112fbd257cd3454a18aacde05e2149171f6" alt="A screenshot of Xcode highlighting the code that is available in a snippet below which allows you to check if a SwiftData object of a specific Id exists within the SwiftData persistent storage container."
Follow the tutorials linked below to add SwiftData to your project, along with the ability to search for all objects, a specific object as well as if an object exists.
Step Two: Add the Create Functionality
data:image/s3,"s3://crabby-images/7c670/7c6707d82ef7957f767526a389fd9744c478d574" alt="A screenshot of Xcode showing the sample functionality that adds a new SwiftData object to a persistent container. The code snippet is available below."
Add functionality similar that below to the project to add new objects to a SwiftData persistent storage container.
We recommend adding this to a file called DataCoordinator+SwiftData.swift, where DataCoordinator is the name of the MainActor singleton that manages the SwiftData.
Please note that the code snippet found above uses a custom error that we created to track SwiftData errors. To learn how to create custom errors, consult the tutorial below.
Step Three: Test
data:image/s3,"s3://crabby-images/944ad/944ad72a676396733294f9afe9321263163bb9cf" alt="A screenshot of an iPhone showing the result of the sample app available on our open source swift GitHub repository."
Add functionality to add new SwiftData objects by calling the function created in Step Two.
Then, run the app and test that it works.
Looking to learn more about things you can do with SwiftData, Swift or XCode ?
Consult our quick start guide or search our blog to find educational content on learning how to use SwiftData, Swift or XCode.