R: how to add array of objects to a record

From: "dfx" <dfx(at)dfx(dot)it>
To: <pgsql-general(at)postgresql(dot)org>
Subject: R: how to add array of objects to a record
Date: 2008-02-03 21:00:04
Message-ID: 000001c866a7$c023ea90$f400a8c0@SEMPRON
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general

Yes, this is the "normal" way, but I was tempted to investigate the
possibility
to use array (of string) or composite types to avoid to increase the number
of tables
and to simplify stored procedures reducing the number of join.

Thi idea was born following the discussion concerning EAV.

Thank you for contribute.

Domenico

-----Messaggio originale-----
Da: pgsql-general-owner(at)postgresql(dot)org
[mailto:pgsql-general-owner(at)postgresql(dot)org]Per conto di Joris
Dobbelsteen
Inviato: domenica 3 febbraio 2008 12:16
A: dfx(at)dfx(dot)it; pgsql-general(at)postgresql(dot)org
Oggetto: Re: [GENERAL] how to add array of objects to a record

>-----Original Message-----
>From: pgsql-general-owner(at)postgresql(dot)org
>[mailto:pgsql-general-owner(at)postgresql(dot)org] On Behalf Of dfx
>Sent: Sunday, 3 February 2008 10:38
>To: pgsql-general(at)postgresql(dot)org
>Subject: [GENERAL] how to add array of objects to a record
>
>Hi list,
>
>Can I add an array of object to a record?
>
>For example if I have a class (or type) phone_number:
>
>create type phone_number as(
>name char(20),
>caption char(50),
>ph_num char(25));
>
>and I would like associate several (unknown number, a priori)
>phone numbers to a record "persons"
>can I create a table like this:
>
>create table persons(
>id integer,
>first_name char(50),
>family_name char(50),
>phone_numbers phone_number[])
>
>and how I have to write the insert and the select queries to
>put and get the array of phone numbers?

Its an SQL database, do not fall back to paradigms from imperative
programming languages (like C, Java, PHP, Perl, ...). Postgres is an
implementation of the relational model, which works very nice on sets.
It does not have a good concept of pointers and alike (they can be
represented, but inefficiently).

Transform you type into a table and add an "id" attribute that
references the persons table (using a foreign key). At this point you
can use regular SQL statements.

- Joris

---------------------------(end of broadcast)---------------------------
TIP 3: Have you checked our extensive FAQ?

http://www.postgresql.org/docs/faq

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Shane Ambler 2008-02-03 21:05:11 Re: [OT] "advanced" database design (long)
Previous Message Myk 2008-02-03 19:57:00 Function returning subset of columns from table (return type)