Re: Inserting NULL into Integer column

From: "scott(dot)marlowe" <scott(dot)marlowe(at)ihs(dot)com>
To: Jeremy Smith <jer(at)highboard(dot)com>
Cc: <pgsql-sql(at)postgresql(dot)org>
Subject: Re: Inserting NULL into Integer column
Date: 2004-02-18 19:43:34
Message-ID: Pine.LNX.4.33.0402181239030.2832-100000@css120.ihs.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers pgsql-sql

On Wed, 18 Feb 2004, Jeremy Smith wrote:

> Hi,
>
> in mysql I was able to make an insert such as:
>
> INSERT INTO TABLE (integervariable) VALUES ('')
>
> and have it either insert that variable, or insert the default if it had
> been assigned. In postgresql it gives and error every time that this is
> attempted. Since I have so many queries that do this on my site already, is
> there any way to set up a table so that it just accepts this sort of query?

First off, the reason for this problem is that Postgresql adheres to the
SQL standard while MySQL heads off on their own, making it up as they go
along. This causes many problems for people migrating from MySQL to
almost ANY database.

Phew, now that that's out of the way, here's the standard ways of doing
it.

Use DEFAULT: If no default is it will insert a NULL, otherwise the
default will be inserted:
insert into table (integervar) values (DEFAULT);

OR

Leave it out of the list of vars to be inserted
insert into table (othervars, othervars2) values ('abc',123);

OR

Insert a NULL if that's what you want:

insert into table (integervar) values (NULL);

Note that NULL and DEFAULT are not quoted.

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Barry Lind 2004-02-18 19:44:21 Re: [PATCHES] NO WAIT ...
Previous Message Rod Taylor 2004-02-18 19:27:56 Re: [PATCHES] NO WAIT ...

Browse pgsql-sql by date

  From Date Subject
Next Message elein 2004-02-18 20:05:47 Re: CHAR(n) always trims trailing spaces in 7.4
Previous Message Jeremy Smith 2004-02-18 19:25:19 Inserting NULL into Integer column