Re: Lookup tables

From: Michał Kłeczek <michal(at)kleczek(dot)org>
To: Karsten Hilbert <Karsten(dot)Hilbert(at)gmx(dot)net>
Cc: pgsql-general(at)lists(dot)postgresql(dot)org, PG-General Mailing List <pgsql-general(at)postgresql(dot)org>
Subject: Re: Lookup tables
Date: 2025-02-04 17:08:56
Message-ID: 6DCD3899-51A8-4032-A189-F2B51AD7CC8F@kleczek.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgadmin-support pgsql-general

> On 4 Feb 2025, at 17:51, Karsten Hilbert <Karsten(dot)Hilbert(at)gmx(dot)net> wrote:
>
> Am Tue, Feb 04, 2025 at 05:31:13PM +0100 schrieb Michał Kłeczek:
>
>> It is now completely unclear what it means to change the name of the restaurant for already registered visits.
>> Is it still the same restaurant with a different name or a different restaurant?
>>
>> Or let say someone swaps names of two restaurants.
>> That means a user that goes to the same restaurant every day would register visits to two different restaurants!
>>
>> Using the name of a restaurant as primary key gets rid of these logical anomalies because
>> the database model now reflects facts from reality.
>
> Reality tends to become so ambiguous as to not be
> reflectable (two entirely different restaurants eventually,
> within the flow of time, carry the very same name).
>
> A primary key is very likely not the proper place to reflect
> arbitrary business logic (is it the same restaurant or not ?
> what if two restaurants have the same name at the same time

These are of course problems ( and beyond the scope of my contrived example ).

The point is though, that having surrogate PK not only does not solve these issues but makes them worse by kicking the can down the road and allowing for inconsistencies.


Michał

In response to

Responses

Browse pgadmin-support by date

  From Date Subject
Next Message Ron Johnson 2025-02-04 17:10:03 Re: Lookup tables
Previous Message Rob Sargent 2025-02-04 17:05:42 Re: Lookup tables

Browse pgsql-general by date

  From Date Subject
Next Message Ron Johnson 2025-02-04 17:10:03 Re: Lookup tables
Previous Message Rob Sargent 2025-02-04 17:05:42 Re: Lookup tables