Comment utiliser la base de données Oracle en programmation PHP ?

PHPz
Libérer: 2023-06-12 08:58:01
original
1650 Les gens l'ont consulté

En tant que base de données mature et stable, Oracle est largement utilisé dans le développement d'applications au niveau de l'entreprise. En tant que langage de programmation côté serveur couramment utilisé, PHP peut également être intégré à la base de données Oracle. Cet article explique comment utiliser la base de données Oracle dans la programmation PHP.

  1. Installer Oracle Instant Client
    L'utilisation de la base de données Oracle en PHP nécessite l'installation d'Oracle Instant Client, qui fournit les fichiers de bibliothèque client requis pour accéder à la base de données Oracle. Vous pouvez télécharger le client Oracle Instant Client correspondant à la version du système d'exploitation depuis le site officiel d'Oracle et l'installer sur le serveur. Il convient de noter que la version PHP correspondante d'Instant Client doit être installée, sinon elle ne fonctionnera pas correctement.
  2. Installer l'extension PHP
    L'utilisation de la base de données Oracle en PHP nécessite l'installation de l'extension Oracle OCI. OCI est une API fournie par Oracle pour communiquer avec la base de données Oracle, donc le "OCI" de l'extension PHP signifie Oracle Call Interface. L'extension OCI de PHP peut être téléchargée à partir de PECL (PHP Extension Community Library), mais cela nécessite l'installation préalable de PEAR (PHP Extension and Application Repository), ce qui est un processus compliqué. Par conséquent, il est recommandé d'utiliser la commande pecl directement sur le serveur à installer.

Dans les systèmes Linux, vous pouvez utiliser la commande suivante pour installer l'extension OCI :

pecl install oci8
Copier après la connexion

Dans les systèmes Windows, vous pouvez activer les extensions OCI en modifiant le fichier de configuration php.ini.

  1. Configurer l'environnement d'exécution PHP
    Après avoir installé l'extension OCI, vous devez activer l'extension OCI dans le fichier de configuration PHP php.ini. Recherchez les lignes suivantes dans php.ini et assurez-vous qu'elles sont activées :

    extension=oci8.so
    Copier après la connexion

    ou :

    extension=php_oci8.dll
    Copier après la connexion

    De plus, vous devez définir les paramètres de connexion de la base de données Oracle dans php.ini :

    oci8.connection_class = MYAPP oci8.default_prefetch = 100 oci8.events = Off oci8.max_persistent = -1 oci8.old_oci_close_semantics = Off oci8.persistent_timeout = -1 oci8.ping_interval = 60 oci8.privileged_connect = Off oci8.statement_cache_size = 20
    Copier après la connexion

    Vous devez définir le Paramètres en fonction de la situation réelle Ajustement.

  2. Connexion à la base de données Oracle
    L'utilisation de la base de données Oracle en PHP nécessite une connexion via la fonction oci_connect() fournie par l'extension OCI. Les paramètres de la fonction incluent le nom d'utilisateur Oracle, le mot de passe et la chaîne de connexion. Le nom ou le nom du service, le nom d'hôte et le numéro de port de la base de données Oracle doivent être spécifiés dans la chaîne de connexion. L'exemple de code est le suivant :

    $connection = oci_connect('user', 'password', '//localhost/orcl');
    Copier après la connexion
  3. Exécuter l'instruction SQL
    L'instruction SQL peut être analysée en un curseur exécutable (curseur) via la fonction oci_parse(). Par exemple, le code suivant peut interroger une table Oracle contenant des valeurs et des chaînes :

    $statement = oci_parse($connection, "SELECT * FROM my_table"); oci_execute($statement);
    Copier après la connexion

    Si l'instruction SQL n'est pas exécutée correctement, les informations d'erreur peuvent être obtenues via la fonction oci_error() fournie par l'extension OCI. Pour les opérations de mise à jour, vous pouvez utiliser les fonctions oci_commit() et oci_rollback() pour valider ou annuler la transaction.

  4. Obtenir les résultats de la requête
    Vous pouvez obtenir une ligne d'enregistrements dans l'ensemble de résultats de la requête via le code suivant :

    $row = oci_fetch_assoc($statement);
    Copier après la connexion

    La fonction oci_fetch_assoc() renvoie un tableau, où la clé est le nom de chaque colonne de l'ensemble de résultats, et la valeur correspondante est la ligne qui enregistre la valeur de la colonne correspondante dans . Il convient de noter que si vous souhaitez récupérer plusieurs lignes d'enregistrements, vous devez ajouter une boucle dans la fonction oci_fetch_assoc().

    Ce qui précède est le processus et la méthode de base d'utilisation de la base de données Oracle dans la programmation PHP. Il convient de noter que diverses erreurs sont susceptibles de se produire lors du processus d'intégration avec la base de données Oracle. Pour les erreurs courantes, vous pouvez obtenir des informations sur les erreurs synchrones via la fonction oci_error() fournie par l'extension OCI et utiliser la fonction de journalisation d'Oracle pour analyser les problèmes de base de données asynchrone.

    Lorsque vous utilisez la base de données Oracle, vous devez écrire des instructions SQL de manière rigoureuse. En particulier pour les opérations d'insertion et de mise à jour de données, des contrôles et vérifications de sécurité pertinents doivent être effectués pour éviter les problèmes de sécurité tels que les attaques par injection.

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!