Valor de retorno de OCI_PARSE
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
{
}
?>
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