web-dev-qa-db-fra.com

PHP requête sqlsrv à la base de données

Je suis passé de MySQL à MS SQL Server et j'essaie d'extraire toutes les données de la table des routines. Je suis connecté mais je ne sais pas comment récupérer des données avec sqlsrv. Voici à quel point je suis venu:

$conn_array = array (
    "UID" => "sa",
    "PWD" => "root",
    "Database" => "nih_bw",
);
$conn = sqlsrv_connect('BILAL', $conn_array);
if ($conn){
    echo "connected";
    $result = sqlsrv_query($db->db_conn,"SELECT * FROM routines");
}else{
    die(print_r(sqlsrv_errors(), true));
}
sqlsrv_close($conn);
?>
10
user3185936

Premièrement, si je ne me trompe pas, vous stockez le résultat sqlsrv_connect dans $conn et que ce résultat n'est pas une classe obj c'est une ressource, supprimez donc $db->conn

Cet exemple connectera, puis récupérera s'il y a des ressources renvoyées par sqlsrv_query

$conn_array = array (
    "UID" => "sa",
    "PWD" => "root",
    "Database" => "nih_bw",
);
$conn = sqlsrv_connect('BILAL', $conn_array);
if ($conn){
    echo "connected";
    if(($result = sqlsrv_query($conn,"SELECT * FROM routines")) !== false){
        while( $obj = sqlsrv_fetch_object( $result )) {
              echo $obj->colName.'<br />';
        }
    }
}else{
    die(print_r(sqlsrv_errors(), true));
}
10
Quijote Shin

Une fois que vous avez exécuté la requête avec sqlsrv_query, vous pouvez récupérer les résultats, par exemple, en utilisant sqlsrv_fetch_array:

$result = sqlsrv_query($db->db_conn, "SELECT * FROM routines");
if($result === false) {
    die( print_r( sqlsrv_errors(), true) );
}

while( $row = sqlsrv_fetch_array($result, SQLSRV_FETCH_ASSOC) ) {
    echo $row['column1'].", ".$row['column2']."<br />";
}
1
Mureinik

Essaye ça: 

while( $row = sqlsrv_fetch_array( $result, SQLSRV_FETCH_ASSOC) ) {
  var_dump($row);
}

sqlsrv_free_stmt($result);
0
Grzegorz Motyl