sqlsrv_preparePrépare une requête pour exécution
&reftitle.description;
mixedsqlsrv_prepareresourceconnstringsqlarrayparamsarrayoptions
Prépare une requête pour exécution. Cette fonction est idéale pour
préparer une requête qui sera exécutée plusieurs fois avec des
valeurs de paramètres différents.
&reftitle.parameters;
conn
Une ressource de connexion retournée par la fonction
sqlsrv_connect.
sql
La chaîne qui définit la requête à préparer et à exécuter.
params
Un tableau spécifiant les informations de paramètres lors de l'exécution
d'une requête contenant des paramètres. Les éléments du tableau peuvent
être n'importe lequel de ceux qui suivent :
Une valeur litéraleUne variable PHPUn tableau avec la structure suivante :
array($value [, $direction [, $phpType [, $sqlType]]])
La table suivante décrit les éléments de la structure du tableau ci-dessus :
Structure du tableauElémentDescription$valueUne valeur liétrale, une variable PHP ou une variable PHP passée par référence.$direction (optional)Une des constantes SQLSRV suivantes, utilisées pour indiquer la
direction du paramètre : SQLSRV_PARAM_IN, SQLSRV_PARAM_OUT, SQLSRV_PARAM_INOUT.
La valeur par défaut est SQLSRV_PARAM_IN.
$phpType (optional)Une constante SQLSRV_PHPTYPE_* qui spécifie le type de données PHP
de la valeur retournée.$sqlType (optional)Une constante SQLSRV_SQLTYPE_* qui spécifie le type de données
du serveur SQL de la valeur d'entrée.
options
Un tableau spécifiant les options de propriétés de la requête.
Les clés supportées sont décrites dans le tableau suivant :
Options de la requêteCléValeursDescriptionQueryTimeoutUne valeur entière positive.Définit le délai maximal d'exécution de la requête, en seconde.
Par défaut, le driver attendra indéfiniment les résultats.SendStreamParamsAtExec&true; ou &false; (par défaut, &true;)Configure le driver pour envoyer les données du flux à l'exécution (&true;),
ou envoyer les données du flux par morceaux (&false;). Par défaut, la valeur
est définie à &true;. Pour plus d'informations, reportez-vous à la fonction
sqlsrv_send_stream_data.ScrollableSQLSRV_CURSOR_FORWARD, SQLSRV_CURSOR_STATIC, SQLSRV_CURSOR_DYNAMIC,
ou SQLSRV_CURSOR_KEYSETVoir la section sur la
sécification d'un type de curseur et la sélection de lignes de la documentation
Microsoft SQLSRV.
&reftitle.returnvalues;
Retourne une ressource de requête en cas de succès, ou &false; si une
erreur survient.
&reftitle.examples;
Exemple avec sqlsrv_prepare
Cet exemple montre la façon de préparer une requête avec la fonction
sqlsrv_prepare et sa ré-exécution à plusieurs reprises
(avec des valeurs de paramètres différents) en utilisant la fonction
sqlsrv_execute.
"dbName", "UID"=>"username", "PWD"=>"password");
$conn = sqlsrv_connect( $serverName, $connectionInfo);
if( $conn === false) {
die( print_r( sqlsrv_errors(), true));
}
$sql = "UPDATE Table_1
SET OrderQty = ?
WHERE SalesOrderID = ?";
// Initialise les paramètres et prépare la requête.
// Les variables $qty et $id sont liées à la requête $stmt.
$qty = 0; $id = 0;
$stmt = sqlsrv_prepare( $conn, $sql, array( &$qty, &$id));
if( !$stmt ) {
die( print_r( sqlsrv_errors(), true));
}
// Définit les informations SalesOrderDetailID et OrderQty.
// Ce tableau lie l'ordre des IDs avec l'ordre des quantités avec des paires clé=>valeur.
$orders = array( 1=>10, 2=>20, 3=>30);
// Exécute la requête pour chaque ordre.
foreach( $orders as $id => $qty) {
// En raison du fait que $id et $qty sont liés à $stmt1,
// leurs valeurs mises à jour sont utilisées lors de chaque exécution
// de la requête.
if( sqlsrv_execute( $stmt ) === false ) {
die( print_r( sqlsrv_errors(), true));
}
}
?>
]]>
&reftitle.notes;
Lorsque vous préparez une requête qui utilisent des variables comme paramètres,
les variables sont liées à la requête. Cela signifie que si vous mettez à jour
les valeurs de ces variables, la prochaine exécution de la requête prendra
en compte ces nouvelles valeurs. Pour les requêtes que vous ne prévoyez
exécuter qu'une seule fois, utilisez la fonction
sqlsrv_query.
&reftitle.seealso;
sqlsrv_executesqlsrv_query