Maison >base de données >tutoriel mysql >Comment calculer efficacement les totaux d'exécution dans SQL Server?
Introduction
L'opération de calcul est une tâche courante dans l'analyse des données. Dans SQL Server, il existe de nombreuses façons d'atteindre cet objectif, notamment en utilisant des fonctions de fenêtre, une sous-requête associée et des solutions basées sur le curseur. "Juxu Setting Skills" est une méthode de discussion. Cette technologie consiste à insérer des lignes dans une table temporaire avec un fonctionnement vide, à mettre à jour le tableau dans un ordre spécifique et à finalement à sélectionner le total de l'opération mise à jour.
Compétences des phrases d'ensemble agrégées
Les requêtes suivantes utilisent les compétences de la phrase d'ensemble agrégé pour calculer le total de l'opération:
Cette méthode est considérée comme efficace car elle est mise à jour dans l'ordre recherché. Cependant, les gens sont préoccupés par leur fiabilité dans toutes les scènes.La méthode alternative d'agrégation des compétences de déclaration
<code class="language-sql">INSERT INTO @AnotherTbl(id, somedate, somevalue, runningtotal) SELECT id, somedate, somevalue, null FROM TestTable ORDER BY somedate DECLARE @RunningTotal int SET @RunningTotal = 0 UPDATE @AnotherTbl SET @RunningTotal = runningtotal = @RunningTotal + somevalue FROM @AnotherTbl</code>
<.> 1. Fonction de fenêtre:
SQL Server 2012 introduit une clause excessive pour permettre à la fonction d'utilisation de la fenêtre (telle que la somme avec une agrégation cumulative). Cela élimine le besoin d'opérations de surface supplémentaires et simplifie la requête:
<.> 2. Sous-femerie associée:
La sous-foyer associée peut être utilisée pour récupérer le fonctionnement de chaque ligne:
<code class="language-sql">SELECT somedate, somevalue, SUM(somevalue) OVER(ORDER BY somedate) AS RunningTotal FROM TestTable</code>
<.> 3. Solution basée sur la distribution:
Le curseur fournit un mécanisme de traitement progressif (dans un ordre spécifique). Le fonctionnement de calcul incrémentiel de la solution basée sur le curseur suivant Total:
<code class="language-sql">SELECT somedate, somevalue, ( SELECT SUM(somevalue) FROM TestTable b WHERE b.somedate < a.somedate ) AS RunningTotal FROM TestTable a</code>Conclusion
Dans SQL Server, la méthode totale de calcul de l'opération de l'opération dépend de facteurs tels que la taille des données, les exigences de performances et la version SQL Server. La "compétences de phrase de paramètres agrégées" est toujours un choix possible pour les mises à jour à haute efficacité, et la fonction de fenêtre fournit une grammaire plus directe dans la nouvelle version de SQL Server. Tenez compte des solutions liées à la sous-requête et à la curseur pour obtenir la flexibilité et le contrôle. Il est recommandé d'effectuer le test de référence pour déterminer la meilleure façon dans des scénarios spécifiques.
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!