Connaissances Informatiques >> Matériel >> Souris et claviers >> Content
  Derniers articles
  • Comment charger une souris sans fil …
  • Problèmes avec le modèle de souris…
  • Comment créer un dinosaure en utili…
  • Comment utiliser le clavier comme so…
  • Quelle est la fonction de la souris …
  • Quel est le son émis par une souris…
  • Comment puis-je changer bas au plus …
  • Claviers Bluetooth qui travaillent a…
  • Inconvénients de l'utilisation d'un…
  • Comment convertir un clavier PS2 à …
  •   Souris et claviers
  • All-In -One Printers

  • apple Computers

  • BIOS

  • Lecteurs CD et DVD

  • CPUs

  • Durs et stockage

  • Écrans d'ordinateur

  • Périphériques

  • Computer Power Sources

  • Imprimantes

  • À niveau des ordinateurs

  • Ordinateurs de bureau

  • Lecteurs de livres électroniques

  • Disques durs externes

  • flash Drives

  • Entrée et de sortie Devices

  • Kindle

  • Portables

  • mainframes

  • Souris et claviers

  • netbooks

  • Matériel réseau

  • Ordinateurs portables

  • Ordinateurs PC

  • Projecteurs

  • RAM , cartes et mères

  • scanners

  • serveurs

  • Cartes son

  • Tablet PC

  • Cartes graphiques

  • Stations de travail

  • iPad

  • iPhone
  •  
    Souris et claviers

    Que sont les curseurs ?

    Les curseurs sont des objets de base de données qui vous permettent d'accéder aux données et de les manipuler une ligne à la fois à partir d'un jeu de résultats renvoyé par une requête SQL. Considérez-les comme des pointeurs qui parcourent les lignes d'un ensemble de résultats.

    Voici un aperçu de ce qu’ils sont et pourquoi ils sont utilisés :

    Concepts clés :

    * Ensemble de résultats : Une collection de lignes renvoyées par une requête SQL. Lorsque vous exécutez une instruction `SELECT`, le serveur de base de données génère un jeu de résultats.

    * Traitement ligne par ligne : Les curseurs vous permettent de récupérer et de traiter chaque ligne de l'ensemble de résultats individuellement. Cela contraste avec les opérations SQL standard qui opèrent généralement sur l’ensemble du jeu de résultats en même temps.

    * Pointeur/Itérateur : Un curseur agit essentiellement comme un pointeur ou un itérateur qui garde la trace de la ligne en cours d'accès. Vous pouvez déplacer le curseur vers l'avant pour accéder aux lignes suivantes.

    Pourquoi utiliser des curseurs ?

    Les curseurs sont généralement utilisés lorsque vous devez effectuer des opérations complexes sur chaque ligne d'un jeu de résultats difficiles, voire impossibles à réaliser avec des instructions SQL standard. Les scénarios courants incluent :

    * Mises à jour/suppressions conditionnelles : Vous devrez peut-être mettre à jour ou supprimer une ligne en fonction des valeurs trouvées dans d'autres lignes du même jeu de résultats ou dans d'autres tables.

    * Calculs basés sur les lignes précédentes : Vous devrez peut-être calculer un total cumulé, une moyenne mobile ou toute autre valeur cumulée qui dépend des valeurs des lignes précédentes.

    * Intégration avec des systèmes externes : Vous devrez peut-être récupérer des données d'une base de données, puis utiliser ces données pour interagir avec des applications ou des API externes, en traitant chaque ligne individuellement.

    * Logique complexe dans les procédures stockées : Les curseurs sont souvent utilisés dans les procédures stockées lorsque vous devez implémenter une logique métier complexe qui nécessite une itération dans un ensemble de résultats.

    * Rapports : La génération de rapports personnalisés ou l'exécution d'un formatage de données complexe repose souvent sur un traitement ligne par ligne.

    Fonctionnement des curseurs (simplifié) :

    1. Déclarez le curseur : Vous déclarez d'abord un curseur, en spécifiant l'instruction `SELECT` qui générera le jeu de résultats avec lequel le curseur fonctionnera.

    2. Ouvrez le curseur : L'ouverture du curseur exécute l'instruction `SELECT` et crée le jeu de résultats. Le curseur est positionné avant la première ligne.

    3. Récupérer les lignes : Vous utilisez une instruction `FETCH` pour récupérer les données de la ligne actuelle et déplacer le curseur vers la ligne suivante.

    4. Traitez les données : Dans une boucle, vous traitez les données récupérées de chaque ligne. Cela peut impliquer la mise à jour d'autres tables, l'exécution de calculs ou l'appel de procédures externes.

    5. Fermez le curseur : Après avoir traité toutes les lignes, vous fermez le curseur, libérant ainsi les ressources qu'il utilisait.

    6. Désaffectez le curseur : Enfin, vous libérez le curseur.

    Exemple (Conceptuel – La syntaxe spécifique varie selon la base de données) :

    ```sql

    -- Déclarer un curseur

    DÉCLARE mon_curseur CURSEUR POUR

    SELECT employ_id, salaire FROM employes WHERE Department_id =10 ;

    -- Ouvrez le curseur

    OUVRIR mon_curseur ;

    -- Récupérer la première ligne

    FETCH NEXT FROM my_cursor INTO @emp_id, @salary ;

    -- Parcourez l'ensemble de résultats

    WHILE @@FETCH_STATUS =0 -- Vérifiez si la récupération a réussi

    COMMENCER

    -- Traiter les données (exemple :augmenter le salaire si en dessous d'un seuil)

    SI @salaire <50000

    COMMENCER

    UPDATE employés SET salaire =salaire * 1.10 OÙ employé_id =@emp_id ; -- Augmenter le salaire de 10%

    FIN;

    -- Récupérer la ligne suivante

    FETCH NEXT FROM my_cursor INTO @emp_id, @salary ;

    FIN;

    -- Fermez le curseur

    FERMER mon_curseur ;

    -- Désallouer le curseur

    DEALLOCATE mon_curseur ;

    ```

    Considérations importantes et inconvénients :

    * Impact sur les performances : Les curseurs peuvent être considérablement plus lents que les opérations SQL basées sur des ensembles, en particulier lorsqu'il s'agit de grands ensembles de résultats. Le traitement ligne par ligne est intrinsèquement moins efficace que le traitement des données par lots. Dans la mesure du possible, essayez d'obtenir le résultat souhaité à l'aide de requêtes SQL standard.

    * Complexité : Les curseurs peuvent rendre votre code plus complexe et plus difficile à maintenir.

    * Problèmes de verrouillage : Les curseurs peuvent verrouiller les ressources de la base de données pendant des périodes plus longues, ce qui peut entraîner des conflits et des problèmes de performances.

    * Alternatives : Avant de recourir aux curseurs, explorez des alternatives telles que :

    * Opérations SQL basées sur des ensembles : Souvent, vous pouvez obtenir le même résultat avec une requête SQL intelligente.

    * Procédures stockées avec tables temporaires : Créez une table temporaire pour contenir le jeu de résultats intermédiaire, puis effectuez des opérations sur la table temporaire.

    Utilisation du code d'application (par exemple, Python, Java) pour traiter les données : Récupérez l’intégralité du jeu de résultats dans votre application et effectuez-y le traitement ligne par ligne. Cela peut parfois être plus efficace que l'utilisation de curseurs.

    En résumé, les curseurs sont un outil puissant mais souvent moins efficace pour le traitement ligne par ligne dans les bases de données. Utilisez-les uniquement lorsque cela est nécessaire et examinez attentivement les implications en termes de performances. Efforcez-vous d'utiliser des opérations SQL basées sur des ensembles autant que possible.

     
    Article précédent:
    Article suivant:
    Articles recommandés
  • Qui a inventé le clavier MIDI? 
  • Quels symboles pouvez-vous créer sur un clavier anglais standard ? 
  • Pouvez-vous glisser-déposer en utilisant le clic droit de la souris ? 
  • Comment vous enseigner frappe au clavier 
  • Acer Aspire 3620 Touchpad de souris ne fonctionne pas 
  • La différence entre une machine à écrire et un clavier d'ordinateur 
  • Comment faire un papillon sur le clavier 
  • Comment accéder aux menus contextuels avec une souris à trois boutons ? 
  • Comment restaurer le Registre de la souris 
  • Comment installer un clavier sans fil et souris sur Vista 
  • Connaissances Informatiques © http://www.ordinateur.cc