Un curseur est une structure de données d'un langage de requête de base de données relationnelle, consistant en un pointeur de données permettant d'effectuer des calculs de variables à travers plusieurs enregistrements. Il introduit un itérateur, qui peut effectuer des opérations, par exemple : ne traiter qu'une ligne sur deux lors de son parcours. L'utilisation consiste à : Déclarer le curseur définissant le jeu d'enregistrement (DECLARE). Ouvrir le curseur pour établir le jeu d'enregistrement (OPEN). Récupérer les données des variables locales (FETCH). Fermer le curseur (CLOSE). Un curseur par défaut traite les données ligne par ligne, mais un curseur scroll n'est pas limité et peut tenir compte des lignes précédentes. En effet ce dernier peut faire appel à des données de façon absolue, à partir du début des enregistrements (FETCH ABSOLUTE), ou relativement à sa position (FETCH RELATIVE). De plus, un curseur peut être SENSITIVE ou INSENSITIVE si on veut qu'il puisse modifier les enregistrements qu'il contient, ou pas. Enfin, un curseur peut être déclaré WITH HOLD pour éviter qu'il ne soit fermé par une transaction informatique. Par ailleurs, un curseur peut être utilisé dans une clause WHERE avec la syntaxe : UPDATE table1 SET champ1 = 0 WHERE CURRENT OF curseur1 On utilise la fonction subsequence() : let result, item-count) DELIMITER DELIMITER ; USE Base1 declare @Nom varchar(20) DECLARE curseur1 CURSOR FOR SELECT Prenom FROM Table1 OPEN curseur1 /* Premier enregistrement de la sélection / FETCH NEXT FROM curseur1 into @Nom print 'Salut ' + @Nom / Traitement de tous les autres enregistrements dans une boucle */ while @@FETCH_STATUS = 0 begin FETCH NEXT FROM curseur1 into @Nom print 'Salut ' + @Nom end CLOSE curseur1; DEALLOCATE curse