Re: information_schema and not-null constraints

Поиск
Список
Период
Сортировка
От Vik Fearing
Тема Re: information_schema and not-null constraints
Дата
Msg-id ef1ea3b5-6a93-9b0e-6ece-12b013b3f0aa@postgresfriends.org
обсуждение исходный текст
Ответ на Re: information_schema and not-null constraints  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-hackers
On 9/6/23 05:40, Tom Lane wrote:
> Vik Fearing <vik@postgresfriends.org> writes:
>> On 9/6/23 02:53, Tom Lane wrote:
>>> What solution do you propose?  Starting to enforce the spec's rather
>>> arbitrary requirement that constraint names be unique per-schema is
>>> a complete nonstarter.  Changing the set of columns in a spec-defined
>>> view is also a nonstarter, or at least we've always taken it as such.
> 
>> I both semi-agree and semi-disagree that these are nonstarters.  One of
>> them has to give.
> 
> [ shrug... ] if you stick to a SQL-compliant schema setup, then the
> information_schema views will serve for introspection.  If you don't,
> they won't, and you'll need to look at Postgres-specific catalog data.


As someone who regularly asks people to cite chapter and verse of the 
standard, do you not see this as a problem?

If there is /one thing/ I wish we were 100% compliant on, it's 
information_schema.


> This compromise has served for twenty years or so, and I'm not in a
> hurry to change it.  


Has it?  Or is this just the first time someone has complained?


> I think the odds of changing to the spec's
> restriction without enormous pushback are nil, and I do not think
> that the benefit could possibly be worth the ensuing pain to users.


That is a valid opinion, and probably one that will win out for quite a 
while.


> (It's not even the absolute pain level that is a problem, so much
> as the asymmetry: the pain would fall exclusively on users who get
> no benefit, because they weren't relying on these views anyway.
> If you think that's an easy sell, you're mistaken.)


I am curious how many people we are selling this to.  In my career as a 
consultant, I have never once come across anyone specifying their own 
constraint names.  That is certainly anecdotal, and by no means means it 
doesn't happen, but my personal experience says that it is very low.

And since our generated names obey the spec (see ChooseConstraintName() 
which even says some apps depend on this), I don't see making this 
change being a big problem in the real world.

Mind you, I am not pushing (right now) to make this change; I am just 
saying that it is the right thing to do.


> It could possibly be a little more palatable to add column(s) to the
> information_schema views, but I'm having a hard time seeing how that
> moves the needle.  The situation would still be precisely describable
> as "if you stick to a SQL-compliant schema setup, then the standard
> columns of the information_schema views will serve for introspection.
> If you don't, they won't, and you'll need to look at Postgres-specific
> columns".  That doesn't seem like a big improvement.  Also, given your
> point about normalization, how would we define the additions exactly?


This is precisely my point.
-- 
Vik Fearing




В списке pgsql-hackers по дате отправления:

Предыдущее
От: Jeremy Schneider
Дата:
Сообщение: Re: Configurable FP_LOCK_SLOTS_PER_BACKEND
Следующее
От: Bruce Momjian
Дата:
Сообщение: Re: Obsolete reference to pg_relation in comment