PHPerKaigi 2025

db2_escape_string

(PECL ibm_db2 >= 1.6.0)

db2_escape_string Utilisé pour échapper certains caractères

Description

db2_escape_string(string $string_literal): string

Place des antislashs devant les caractères spéciaux à la chaîne de caractères passée en argument.

Liste de paramètres

string_literal

Une chaîne de caractères qui contient des caractères spéciaux qui doivent être modifiés. Les caractères qui sont transformés à l'aide d'un antislash sont \x00, \n, \r, \, ' " et \x1a.

Valeurs de retour

Retourne string_literal avec les caractères spéciaux mentionnés ci-dessus précédés par des antislashs.

Exemples

Exemple #1 Exemple avec db2_escape_string()

Résultat suite à l'utilisation de la fonction db2_escape_string()

<?php

$conn
= db2_connect($database, $user, $password);

if (
$conn) {
$str[0] = "Tous les caractères : \x00 , \n , \r , \ , ' , \" , \x1a .";
$str[1] = "Antislash (\). Apostrophe ('). Guillemet (\")";
$str[2] = "Le caractère NULL \0 doit être transformé aussi";
$str[3] = "Caractères intéressants : \x1a , \x00 .";
$str[4] = "Rien à transformer";
$str[5] = 200676;
$str[6] = "";

foreach(
$str as $string ) {
echo
"db2_escape_string: " . db2_escape_string($string). "\n";
}
}
?>

L'exemple ci-dessus va afficher :

db2_escape_string: Tous les caractères : \0 , \n , \r , \\ , \' , \" , \Z .
db2_escape_string: Antislash (\\). Apostrophe (\'). Guillemet (\")
db2_escape_string: Le caractère NULL \0 doit être transformé aussi
db2_escape_string: Caractères intéressants : \Z , \0 .
db2_escape_string: Rien à transformer
db2_escape_string: 200676
db2_escape_string:

Voir aussi

add a note

User Contributed Notes 1 note

up
1
hippyjim
15 years ago
One thing to note here - don't know if it applies to all DB2 installations, and I know I'm using an antiquated one, but my DB2 install wants a ' to be quoted rather than slashed.

That means this function is useless to pick up apostrophes ' in strings, as it adds a slash which DB2 ignores.

You'll need to use something like str_replace to swap your ' for ''.
To Top