Pergunta

Qual será a condição de se, onde eu quiser executar algum comando dentro, se, se não houver linha retornada pela consulta.

<?php
  include_once('config.php');
  $db = oci_new_connect(ORAUSER,ORAPASS,"localhost/XE");
  $sql="select * from table_1 where id=3";
  $result=oci_parse($db,$sql);
  oci_result($result);

  if()
  {

  }
  else
  {

  }
?>
Foi útil?

Solução

você poderia usar oci_fetch:

// parse/bind your statement

if (oci_fetch($your_statement)) {
    ... // do something when there is rows
}    
else {
    ... // do something when there is no rows
}

Outras dicas

Depois de atribuir os valores de ligação ao OCI_PARSE (), você precisa executar a consulta com oci_execute (). Esta é a definição da função:

bool OCI_EXECUTE (Recurso $ Declaração [, Int $ Mode = OCI_COMMIT_ON_SUCCESS]))

Retorna verdadeiro sobre sucesso ou falso no fracasso.

Juntando tudo:

<?php

$stmt = oci_parse($conn, $sql);
$res = oci_execute($stmt);
if( !$res ){
    $error = oci_error($stmt);
    echo "Error: " . $error['message'] . "\n";
}else{
    echo "OK\n";
}

?>
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top