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
Libérer: 2025-01-25 03:22:14
original
383 Les gens l'ont consulté

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
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
Copier après la connexion

<.> 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:

SELECT somedate, somevalue,
    SUM(somevalue) OVER(ORDER BY somedate) AS RunningTotal
FROM TestTable
Copier après la connexion

<.> 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:

SELECT somedate, somevalue,
(
    SELECT SUM(somevalue) 
    FROM TestTable b 
    WHERE b.somedate < a.somedate
) AS RunningTotal
FROM TestTable a
Copier après la connexion
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 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 articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal