Perhaps I just have the wrong expectations, but I discovered some odd behavior from SwiftData that sure seems like a bug to me...
If you make any change to any SwiftData model object — even just setting a property to its current value — every SwiftUI view that uses SwiftData is rebuilt. Every query and every entity reference, even if the property was set on a model class that is completely unrelated to the view.
SwiftUI does such a good job of optimizing UI updates that it's hard to notice the issue. I only noticed it because the updates were triggering my debug print statements.
To double-check this, I went back to Apple's new iOS app template — the one that is just a list of dated items — and added a little code to touch an unrelated record in the background:
@Model
class UnrelatedItem {
    var name: String
    
    init(name: String) {
        self.name = name
    }
}
@main
struct jumpyApp: App {
    var sharedModelContainer: ModelContainer = {
        let schema = Schema([
            Item.self,
            UnrelatedItem.self
        ])
        let modelConfiguration = ModelConfiguration(schema: schema, isStoredInMemoryOnly: false)
        do {
            return try ModelContainer(for: schema, configurations: [modelConfiguration])
        } catch {
            fatalError("Could not create ModelContainer: \(error)")
        }
    }()
    
    init() {
        let context = sharedModelContainer.mainContext
        
        // Create 3 items at launch so we immediately have some data to work with.
        if try! context.fetchCount(FetchDescriptor<Item>()) == 0 {
            for _ in 0..<3 {
                let item = Item(timestamp: Date())
                context.insert(item)
            }
        }
        
        // Now create one unrelated item.
        let unrelatedItem = UnrelatedItem(name: "Mongoose")
        context.insert(unrelatedItem)
        
        try? context.save()
        
        // Set up a background task that updates the unrelated item every second.
        Task {
            while true {
                try? await Task.sleep(nanoseconds: 1_000_000_000)
                Task { @MainActor in
                    // We don't even have to change the name or save the contxt.
                    // Just setting the name to the same value will trigger a change.
                    unrelatedItem.name = "Mongoose"
                }
            }
        }
    }
    var body: some Scene {
        WindowGroup {
            ContentView()
        }
        .modelContainer(sharedModelContainer)
    }
}
I also added a print statement to the ContentView so I could see when the view updates.
struct ContentView: View {
    @Environment(\.modelContext) private var modelContext
    @Query private var items: [Item]
    var body: some View {
        NavigationSplitView {
            List {
                let _ = Self._printChanges()
                ...
The result is that the print statement logs 2 messages to the debug console every second. I checked in iOS 17, 18.1, and 18.2, and they all behave this way.
Is this the intended behavior? I thought the whole point of the new Observation framework in iOS 17 was to track which data had changed and only send change notifications to observers who were using that data.