データの削除
単一およびバッチの削除操作で、データベースからドキュメントまたは特定のフィールドを削除します。
Delete 操作を使う理由
ドキュメント全体の削除、複数ドキュメントの一括削除、またはドキュメントから特定フィールドの削除など、データベースからレコードを削除する必要があります。Squid Client SDK は、これら各ケースに対応する delete 操作を提供します。
概要
transaction 内で実行されない限り、すべての delete 操作は、サーバー側で mutation が適用されると resolve される Promise を返します。
他の mutation と同様に、delete はクライアントで楽観的(optimistic)に適用され、その後サーバーと同期されます。optimistic updates の仕組みの詳細は、データの追加 を参照してください。
コアコンセプト
Delete
ドキュメントを削除するには、document reference の delete メソッドを呼び出します。
const userRef = squid.collection<User>('users').doc('existing_user_id');
try {
await userRef.delete();
console.log('User deleted successfully');
} catch (error) {
console.error(`Failed to delete user ${error}`);
}
Delete many
複数のドキュメントをバッチで削除するには、collection reference の deleteMany メソッドを使用します。deleteMany は、ドキュメントまたはドキュメント ID の配列をパラメータとして受け取ります。
const staleDocs = await squid
.collection<User>('users')
.query()
.eq('pending-delete', true)
.snapshot();
try {
await squid.collection<User>('users').deleteMany(staleDocs);
console.log('Users successfully deleted');
} catch (error) {
console.error(`Failed to delete users ${error}`);
}
多数のドキュメントを削除する際は、deleteMany が必要とするのはドキュメント参照であり、ドキュメントの完全なデータではないため、field projection を使用してクエリのペイロードサイズを削減できます。
const staleDocs = await squid
.collection<User>('users')
.query()
.eq('pending-delete', true)
.projectFields([])
.snapshot();
await squid.collection<User>('users').deleteMany(staleDocs);
Delete in path
ドキュメントの特定プロパティを削除するには、document reference の deleteInPath メソッドを呼び出し、削除したいプロパティへの path を渡します。path でネストされたプロパティを指定するにはドット記法を使用します。
const userRef = squid.collection<User>('users').doc('existing_user_id');
try {
await userRef.deleteInPath('contact.email');
console.log('User email deleted successfully');
} catch (error) {
console.error(`Failed to delete user email ${error}`);
}
エラーハンドリング
| Error | Cause | Solution |
|---|---|---|
| Security rule rejection | delete が security rules によりブロックされた | ユーザーが該当コレクションに対する delete 権限を持っていることを確認する |
| Document not found | 存在しないドキュメントを削除しようとしている | ドキュメント ID が正しいことを確認する。ドキュメントがすでに削除されていないか確認する |
| Invalid path | deleteInPath に渡した path がドキュメント上に存在しない | ドット記法で指定した path がドキュメント構造に一致していることを確認する |
ベストプラクティス
-
ループ内で 1 件ずつドキュメントを削除するのではなく、バッチ操作には
deleteMany()を使用する。 -
特にバッチ削除では、削除前にクエリして、どのドキュメントが削除されるかを確認する。
Client codeconst toDelete = await squid
.collection<User>('users')
.query()
.eq('status', 'inactive')
.snapshot();
console.log(`Deleting ${toDelete.length} inactive users`);
await squid.collection<User>('users').deleteMany(toDelete); -
ドキュメントをきれいに保つため、任意(optional)フィールドを
nullや空の値に設定するのではなく、deleteInPath()を使って削除する。 -
すべての削除がまとめて成功または失敗することを保証したい場合は、関連する delete を transaction でラップする。