Handling Unique Constraints in Ecto with on_conflict

Posted on Jun 7, 2024

Handling Unique Constraints in Ecto with on_conflict

When inserting data in Ecto, you may encounter unique constraint violations that clutter your logs. Instead of letting these errors flood your system, you can use on_conflict and conflict_target to define how PostgreSQL should handle conflicts.

Example usage:

Repo.insert!(
  %User{email: "[email protected]"},
  on_conflict: {:replace, [:name]},
  conflict_target: [:email]
)

This instructs PostgreSQL to update the name field if a conflict occurs on the email column. Properly handling conflicts improves database efficiency and keeps logs clean.