| From: | "Tomás A(dot) Rossi" <tomas(at)mecon(dot)gov(dot)ar> | 
|---|---|
| To: | Kris Jurka <books(at)ejurka(dot)com> | 
| Cc: | pgsql-jdbc(at)postgresql(dot)org | 
| Subject: | Re: ResultSet.getInt problem | 
| Date: | 2006-02-17 19:40:14 | 
| Message-ID: | 43F6269E.7090001@mecon.gov.ar | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-jdbc | 
Kris Jurka escribió:
>
>
> On Fri, 17 Feb 2006, "Tomás A. Rossi" wrote:
>
>> ResultSet rs= con.select(query);
>> while (rs.next()) {
>>   id= rs.getInt("id");
>>   out.println(id); // prints 0 in every row!!
>>   name= rs.getString("name"); // ok
>>   ...
>>
>> Now if I change getInt("id") for the other overload getInt(1), it 
>> works fine!
>> (it prints the correct id for every column)
>>
>
> I'm not sure what's going wrong here.  What do you get if you add some 
> additional debugging code along the lines of the following:
>
> ResultSetMetaData rsmd = rs.getMetaData();
> for (int i=1; i<=rsmd.getColumnCount(); i++) {
>     System.out.println("["+rsmd.getColumnName()+"]");
> }
>
> Kris Jurka
The query formed is:
"SELECT * FROM sso.organismos o LEFT OUTER JOIN motivos_bloqueos m ON( 
o.id_motivo_ultimo_bloqueo=m.id) WHERE no(o.baja_fisica) AND nombre ~* 
'a' AND activo ORDER BY nombre"
The table is:
CREATE TABLE sso.organismos
(
  id serial NOT NULL,
  nombre text NOT NULL,
  dominio text NOT NULL,
  activo bool NOT NULL DEFAULT 't',
  fecha_ultima_baja timestamp,
  bloqueado bool NOT NULL DEFAULT 'f',
  cant_bloqueos_heredados int4,
  fecha_ultimo_bloqueo timestamp,
  detalle_ultimo_bloqueo text,
  id_motivo_ultimo_bloqueo int4,
  baja_fisica bool,
  descripcion text,
  CONSTRAINT organismos_pkey PRIMARY KEY (id),
  CONSTRAINT "$1" FOREIGN KEY (id_motivo_ultimo_bloqueo)
      REFERENCES sso.motivos_bloqueos (id)
      ON UPDATE NO ACTION ON DELETE NO ACTION DEFERRABLE INITIALLY DEFERRED,
  CONSTRAINT organismos_nombre_key UNIQUE (nombre)
)
Your debug code printed:
"[id] [nombre] [dominio] [activo] [fecha_ultima_baja] [bloqueado] 
[cant_bloqueos_heredados] [fecha_ultimo_bloqueo] 
[detalle_ultimo_bloqueo] [id_motivo_ultimo_bloqueo] [baja_fisica] 
[descripcion] [id] [motivo] [baja_fisica]"
Seems that two columns has the same name (id) or something like that? 
How to workaround this?
This didn't happen when using postgres 7.3 with driver 7.3.
Thank you very much,
Tom;
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Kris Jurka | 2006-02-17 19:55:09 | Re: ResultSet.getInt problem | 
| Previous Message | Kris Jurka | 2006-02-17 18:50:35 | Re: PGConnectionPoolDataSource is not a DataSource? |