Maison >base de données >tutoriel mysql >Comment calculer efficacement les totaux d'exécution dans SQL Server?

Comment calculer efficacement les totaux d'exécution dans SQL Server?

Linda Hamilton
Linda Hamiltonoriginal
2025-01-25 03:22:14302parcourir

How to Efficiently Calculate Running Totals in SQL Server?

Calcul de l'opération dans SQL Server Total

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!

Déclaration:
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