Cara, relacionamentos bidirecionais é complicado de lidar e eu nunca esbarrei em uma situação onde fosse necessario. Pra mim, essa discussão é muito parecida com a de heranças multiplas.
Voce tem um exemplo? Acho que seria mais legal discutir com um exemplo palpável em maos.
Usuário e endereço é um bom exemplo, já que toda vez que eu precisar consultar um usuário, também preciso de seu endereço. Se eu utilizo o relacionamento bidirecional, quando eu consultar um usuário, o seu endereço será automaticamente chamado, fazendo com que eu precise fazer somente uma requisição. Se o relacionamento é unidirecional, precisaria fazer uma requisição para consultar o usuário e outra para buscar o seu endereço
Eu gosto de pensar como dependência. A questão aqui é decidir qual das duas entidades é a forte e a fraca.
Nesse sistema
- Endereço faz sentido sem um usuario?
- O usuário faz sentido sem um endereço?
Acho que na maioria das vezes, o endereço nao existe sozinho. Ele seria uma entidade mais fraca.
Na relação
```mermaid
erDiagram
User }|..|{ ADDRESS : has
```
A seguinte query resolve pra quando voce tem o endereço
```sql
SELECT * FROM
Users u JOIN Address addr ON u.id = addr.userId
WHERE addr.id = 42
```
E a seguinte query resolve pra quando voce tem o usuario
```sql
SELECT * FROM
Users u JOIN Address addr ON u.id = addr.userId
WHERE user.id = 42
```
De verdade, nao consigo ver quando a relação bidirecional é melhor que a unidirecional.