Commit 1b22e40
Improve DuplicateKeySyncError (#1119)
* fix: improve DuplicateKeySyncError message for distinct + custom getKey
When using `.distinct()` with a custom `getKey`, the error message now
explains that `.distinct()` deduplicates by the entire selected object,
not by the key field. This helps users understand they should either:
1. Ensure SELECT only includes fields that make up the key
2. Use .groupBy() instead of .distinct() for explicit control
3. Remove the custom getKey to use default key behavior
This addresses a production bug where users were getting confusing
duplicate key errors when combining these features.
* chore: add changeset for improved error message
* fix: remove misleading groupBy suggestion from error message
* fix: add back groupBy suggestion with min()/max() aggregates
---------
Co-authored-by: Claude <[email protected]>1 parent 98e584d commit 1b22e40
5 files changed
Lines changed: 27 additions & 3 deletions
File tree
- .changeset
- packages/db/src
- collection
- query/live
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
150 | 150 | | |
151 | 151 | | |
152 | 152 | | |
| 153 | + | |
153 | 154 | | |
154 | 155 | | |
155 | 156 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
172 | 172 | | |
173 | 173 | | |
174 | 174 | | |
175 | | - | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
176 | 180 | | |
177 | 181 | | |
178 | 182 | | |
179 | | - | |
180 | | - | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
181 | 197 | | |
182 | 198 | | |
183 | 199 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
227 | 227 | | |
228 | 228 | | |
229 | 229 | | |
| 230 | + | |
230 | 231 | | |
231 | 232 | | |
232 | 233 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
| 15 | + | |
15 | 16 | | |
0 commit comments