Foros del Web » Programando para Internet » PHP »

Seleccionar unico registro postgres

Estas en el tema de Seleccionar unico registro postgres en el foro de PHP en Foros del Web. Buenas!! Tengo una duda al crear una funcion de php con postgres. NEcesito que me devuelva un valor entero que sea el id de una ...
  #1 (permalink)  
Antiguo 03/03/2012, 00:08
Avatar de radus  
Fecha de Ingreso: agosto-2011
Mensajes: 9
Antigüedad: 12 años, 8 meses
Puntos: 0
Pregunta Seleccionar unico registro postgres

Buenas!! Tengo una duda al crear una funcion de php con postgres. NEcesito que me devuelva un valor entero que sea el id de una tabla en la cual voy a insertar.

public function verificoNroInscripcion () {
//Devuelvo el proximo numero de inscripcion que requerira el usuario a agregar (o 0 si no encuentra)
$sql = "SELECT MAX(id)+1 FROM personas;";
$query = pg_query($this->getConexion(), $sql);
// verifico haya encontrado
if ($registro = pg_fetch_row($query)) {
return $registro[0];
} else {
return 0;
}
}

Por alguna razon no funciona, no estoy segura si es porque no me devuelve un entero sino una cadena, o porque el $registro[0] no es lo que yo deseo, o qué me estoy olvidando.
¿PAra que me devuelva un entero, que me sugieren corregir?
  #2 (permalink)  
Antiguo 03/03/2012, 06:14
Avatar de maycolalvarez
Colaborador
 
Fecha de Ingreso: julio-2008
Ubicación: Caracas
Mensajes: 12.120
Antigüedad: 15 años, 9 meses
Puntos: 1532
Respuesta: Seleccionar unico registro postgres

Te recomiendo usar la librería PDO, Además en postgres utilizas los sequence para ese propósito
__________________
¡Por favor!: usa el highlight para mostrar código
El que busca, encuentra...
  #3 (permalink)  
Antiguo 03/03/2012, 10:50
Avatar de radus  
Fecha de Ingreso: agosto-2011
Mensajes: 9
Antigüedad: 12 años, 8 meses
Puntos: 0
Respuesta: Seleccionar unico registro postgres(SOLUCIONADO)

Es bastante interesante el tema del PDO, ahora lo voy a leer, pero mientras hice un parche para que funcione mi función, la dejo por si alguien la necesita (no aseguro sea lo mejor)

Código PHP:
    public function verificoNroInscripcion () {
        
//Devuelvo el proximo numero de inscripcion que requerira el usuario a agregar (o 0 si no encuentra)
        
$sql "select max (nro_inscripcion) from personas";
        
$result pg_query($this->getConexion(), $sql);
        
// verifico haya insertado 
        
if (!query) { 
            return -
1;
        } else { 
            
$arr pg_fetch_array($result);
            
$nro_incripcion + (int)$arr[0];
            return 
$nro_incripcion;
        }  
    } 
de todas formas, si se animan a traducirla con funciones pdo mejor
Muchas gracias por responder!

Etiquetas: max, pg_fetch_row, postgres
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 01:56.