Wednesday, 13 September 2017

Wie Zu Berechnen A Moving Average In Ms Zugriff


Neue Daten werden der Tabelle täglich von Montag bis Freitag hinzugefügt, basierend auf den Börsenkursänderungen für diesen Tag. Die aktuelle Anforderung beruht auf dem VOLUME-Feld, das das für eine bestimmte Aktie täglich gehandelte Volumen anzeigt. VORAUSSETZUNG Um das Durchschnitts - und Gesamtvolumen für die letzten 10,15 bzw. 30 Tage zu erhalten. METHODE verwendet CURRENTLY - Ich schuf diese 9 SEPARATE QUERIES, um meine gewünschten Ergebnisse zu erhalten Zuerst habe ich diese 3 Abfragen erstellt, um die letzten letzten 10,15 und 30 Termine aus der aktuellen Tabelle. qryLast10DaysStored qryLast15DaysStored qryLast30DaysStored Dann habe ich geschaffen, um diese drei Anfragen für immer die jeweiligen Durchschnitte qrySymbolAvgVolume10Days qrySymbolAvgVolume15Days qrySymbolAvgVolume30Days Und dann habe ich diese drei Abfragen erstellt für das Erhalten der jeweiligen TOTALS qrySymbolTotalVolume10Days qrySymbolTotalVolume15Days qrySymbolTotalVolume30Days PROBLEM MIT aktuellen Methode konfrontiert - Nun, mein Problem ist, dass ich am Ende haben Up mit diesen so viele verschiedene Abfragen, während ich wollte die Ausgabe in One Single Query, wie im Schnappschuss des Excel Sheet gezeigt. LÖSUNG BENÖTIGT - Gibt es eine Möglichkeit, mit der ich diese erforderlichen Felder in ONE SINGLE QUERY zu bekommen, so dass ich nicht haben, um in mehrere Orte für die erforderlichen Felder aussehen Kann mir bitte jemand sagen, wie man all diese separaten Abfragen in einem - A) Entweder durch Herausnehmen oder Verschieben der Ergebnisse aus diesen separaten Einzelabfragen zu einem. B) Oder indem Sie eine neue Abfrage erstellen, die alle diese Felder in sich berechnet, sodass diese einzelnen Einzelabfragen nicht mehr benötigt werden. Das wäre eine bessere Lösung, denke ich. Eine Klärung über Daten Einige Freund könnte denken, warum ich die Methode der Verwendung von Top 10,15 und 30 für immer die letzten 10,15 und 30 Datumswerte verwendet. Warum nicht habe ich gerade den PC Datum für das Erhalten dieser Werte Oder verwendet so etwas wie - (VOLUME, tbl-B, TimeStamp ZWISCHEN Datum () - 10 UND Datum ()) Die Antwort ist, dass ich meine Abfrage verlange, um das Datum aus dem lesen TIMESTAMP Field, und führen Sie dann seine Berechnungen entsprechend für LETZTE MOST RECENT 10 Tage, 15 Tage, 30 Tage, für die die Daten verfügbar ist in der Tabelle, OHNE BOTHERING, was das aktuelle Datum ist. Es sollte nicht auf das aktuelle Datum in irgendeiner Weise ab. Wenn es eine bessere Methode oder effizientere Möglichkeit, diese Abfragen zu erstellen, dann bitte erleuchten. PS. Ich habe eine SAMPLE-Datenbank, die die Daten für 6 Monate, vom 1. November 2011 bis 30. April 2012 und es hat auch die oben genannten Fragen in ihm. Beispieldatenbank mit QUERIEN Sie haben separate Abfragen, um 10DayTotalVolume und 10DayAvgVolume zu berechnen. Ich vermute, Sie können beide in einer Abfrage, qry10DayVolumes berechnen. Allerdings ist das frage mich, ob 10DayAvgVolume kann immer etwas anderes als 10DayTotalVolume 10 Ähnliche Überlegungen gelten für die 15 und 30 Tage Werte. Letztendlich glaube ich, dass Sie etwas wollen, das auf einem Ausgangspunkt wie folgt basiert: Das geht davon aus, dass Sie qry15DayVolumes und qry30DayVolumes erstellt haben, nach dem Ansatz, den ich für qry10DayVolumes vorgeschlagen habe. Wenn Sie die Anzahl der Abfragen reduzieren möchten, können Sie Unterabfragen für jede der gespeicherten QryDayVolumes-Abfragen verwenden, aber versuchen Sie es auf diese Weise zuerst, um sicherzustellen, dass die Logik korrekt ist. In dieser zweiten Abfrage oben kann es ein Problem durch Feldnamen geben, die mit Ziffern beginnen. Schließen Sie diese Namen in eckige Klammern oder re-alias sie in qry10DayVolumes. Qry15DayVolumes. Und qry30DayVolumes unter Verwendung von Aliasnamen, die mit Buchstaben anstelle von Ziffern beginnen. Ich testete die Abfrage wie oben geschrieben mit der 2. Upload. mdb Sie hochgeladen, und es lief ohne Fehler von Access 2007. Hier ist die erste Zeile der Ergebnismenge aus dieser Abfrage: beantwortet 24.10.12 um 19: 20 Berechnen von Totalsummen und Verschieben Durchschnittswerte in Microsoft Access mit Total Access Statistiken Microsoft Access bietet keine integrierten Funktionen zur Berechnung der laufenden Summen an. Laufende Summen sind Zusammenfassungen über eine festgelegte Anzahl von Datensätzen. Zum Beispiel ein 30 Tage gleitender Durchschnitt, den Sie für jeden Datensatz basierend auf seinem Wert und seinen vorherigen 29 Datensätzen berechnen möchten. Glücklicherweise führt die Total Access-Statistik eine Vielzahl von Berechnungen für alle Datensätze durch: Führen Sie Zusammenfassungen für einen bewegten Satz von Datensätzen durch, um Summen, Mittelwerte, Minimum, Maximum, Bereich, Median, Standardabweichung usw. zu berechnen Feld in Ihrer Datenquelle Analysieren Sie die Daten in Ihren Access-Tabellen und - Anfragen (einschließlich der verknüpften Daten) Unterstützung von Gruppierungen auf Feldwerten, sodass Sie mehrere Analysen in einem Durchgang durchführen können Totalsätze wurden für Total Access Statistics für Microsoft Access 2007 und X.7 hinzugefügt Versionen für Access 2003 und früher. Ausführen von Totals Übersicht Laufende Summen sind Berechnungen für eine festgelegte Anzahl von Datensätzen über Ihre Tabelle oder Abfrage. Erzeugen Sie Ergebnisse wie Summen, Mittelwerte, Minimum, Maximum, Median usw. und fügen Sie diese in Felder in Ihrer Datenquelle ein. Diese Berechnungen sind verfügbar: mittlere (mittlere) Anzahl Beobachtungen Summe Summenquadrat Minimaler Maximalbereich Standardabweichungsabweichung Abweichungskoeffizient Standardfehler Medianmodus Modusanzahl Geometrisch Mittelwert Harmonisch Mittelwert Wurzel Mittlere Schräglage Kurtosis Standardfehler der Schiefe Standardfehler der Kurtosis Bis zu fünf Felder In Ihrer Tabelle können auf einmal aktualisiert werden. Berechnen des Gesamtbetrages Zum Beispiel können Sie den Durchschnitt der letzten 10 Datensätze berechnen. Dieser gleitende Durchschnitt wird auf der Grundlage der Sortierreihenfolge Ihrer Daten bestimmt, wobei der Mittelwert für diese 10 Datensätze berechnet und in ein Feld gesetzt wird, das Sie mit dem Datensatz 10 angeben. Für Satz 11 wird Satz 1 ignoriert und die Berechnung für Satz 2 bis durchgeführt 11, etc. Wie die anderen Funktionen können Sie Gruppenfelder angeben, so dass jede Gruppe ihre eigenen laufenden Summen hat. Diese Funktion erstellt keine separate Tabelle. Die Ergebnisse werden in die Felder, die Sie in Ihrer Datenquelle angeben, platziert. Feldauswahl für Feldauswahl Im Feld Auswahlauswahl für Laufende Summen können Sie die zu sortierenden Felder und die Felder für die Platzierung der Ergebnisse festlegen: Mit Gruppenfeldern können Sie für jede Kombination von eindeutigen Werten unter den Gruppenfeldern einen eigenen Analysesatz erstellen. Die Sortierfelder bestimmen die Sortierreihenfolge Ihrer Datensätze, um die laufenden Werte zu berechnen. Geben Sie mindestens ein Sortierfeld an. Dies kann das Feld, das Sie die Berechnungen auf. Die Felder werden in aufsteigender Reihenfolge sortiert. Geben Sie bis zu fünf Felder für die Aktualisierung mit Ihren Gesamtsummen an. Stellen Sie sicher, dass die Felder Datentypen sind, die die von Ihnen erwarteten Daten enthalten können. Sie sollten z. B. doppelt sein, wenn Sie Werte wie Durchschnitt (Mittelwert), Varianz usw. speichern möchten. Ausführen von Gesamtoptionen Nach Auswahl der Felder werden die Optionen Laufende Summen angezeigt: Feld zum Analysieren Geben Sie das Feld an, auf dem die Berechnungen basieren. Dieses Feld kann ein Feld sein, das als Sortierfeld angegeben wurde. Sie können z. B. den laufenden Durchschnitt auf der Grundlage des Verkaufs in aufsteigender Reihenfolge sortieren. Anzahl der Datensätze, um Summen zu berechnen Geben Sie die Anzahl der Datensätze in der bewegten Summe an. Wenn Sie 0 angeben, werden die Summen für jeden Datensatz berechnet. Wenn Sie eine bestimmte Zahl eingeben, basieren die Berechnungen auf dieser Anzahl von Datensätzen. Der erste Datensatz wird gelöscht, wenn der nächste hinzugefügt wird und die Berechnungen auf diesen sich bewegenden Satz von Datensätzen basieren. Anfangssatz von Datensätzen Wenn Sie die Anzahl der Datensätze angeben, um Summen zu berechnen, gibt es eine Option, um festzustellen, was geschieht, bevor Sie diese Anzahl von Datensätzen erreichen. Entweder sollten die Summen auf der Grundlage der verarbeiteten Datensätze übersprungen oder berechnet werden. Wählen Sie Berechnen, um die laufenden Summen anzuzeigen, unabhängig davon, ob die Anzahl der bewegten Datensätze erreicht ist. Wählen Sie Leer lassen, um nur die laufenden Summen zu erhalten, wenn die angegebene Anzahl von Datensätzen ohne Berechnungen für eine kleinere Anzahl von Datensätzen erreicht wird. Berechnungsart Es stehen viele Berechnungsarten zur Verfügung. Geben Sie für jedes von Ihnen ausgewählte Aktualisierungsfeld die gewünschte ein. Ergebnisse für die Ausführung von Ergebnissen Die Ergebnisse für die Ausführung der Ergebnisse werden in die angegebenen Aktualisierungsfelder eingefügt: Beispiel für das Ausführen von Totals in den rechten vier Feldern dieser Microsoft Access-Tabelle In diesem Beispiel wurden die Daten nach Datum und Auftrags-ID sortiert Feld. Beachten Sie, dass die Werte in dem RunningCount-Feld von 1 bis 10 zunehmen. Sobald es 10 erreicht, bleibt es bei 10, da dies die maximale Anzahl von Datensätzen in der bewegten Summe ist. Das RunningTotal-Feld zeigt die Summe der Verkäufe über die Datensätze in dem sich bewegenden Satz von Datensätzen an. Da die Option zum Berechnen der Werte für den ersten Satz von Datensätzen ausgewählt wurde (bevor er 10 Datensätze erreichte), werden die Werte angezeigt. Andernfalls würden die ersten 9 Datensätze Nullwerte aufweisen. Interactive Wizard und VBA Programmatic Interfaces Mit Total Access Statistics können Sie Ihre Berechnungen über die Assistentenschnittstelle interaktiv generieren, um die Datenquelle, die Felder und die Analyse ohne Programmierung einfach auszuwählen. Nachdem Sie Ihre Auswahl getroffen haben, werden sie automatisch als ein Szenario in Ihrer Datenbank gespeichert, so dass Sie sie in Zukunft erneut ausführen können, wenn sich Ihre Daten ändern. Eine VBA-Statistik-Funktion ist auch verfügbar, so dass Sie diese Ergebnisse aus Code generieren können. Sie können jedes gespeicherte Szenario problemlos ausführen, indem Sie eine einzelne Prozedur in der VBA-Gesamtbibliothek Total Access Statistics aufrufen. Die Bibliothek enthält eine lizenzfreie Runtime-Lizenz, so dass Sie sie mit Ihrer Access-Datenbank einbinden und an Nicht-Total-Zugriffsstatistikeigentümer verteilen können. Rufen Sie die Funktion aus einem Tasten OnClick-Ereignis oder einem anderen Prozess, und die Ergebnisse werden für Sie generiert. Sie können sogar die eingebaute Benutzeroberfläche zu verstecken, damit Ihre Benutzer nicht einmal wissen, Total Access Statistics ausgeführt wird. Sie werden mit Ihren statistischen Analysemöglichkeiten überrascht Weitere Details zu Berechnungen, die in den Zugriffsstatistiken verfügbar sind Hier sind einige zusätzliche Ressourcen und Details zu einigen Datenanalysen, die Sie auf Ihren Microsoft Access-Daten mit Total Access Statistics durchführen können: Finanz-Cashflow-Berechnungen Verwenden Sie diskontierte Bargeld Ströme und Zinssätze zur Erzielung des Net Present Value (NPV), des Present Value (PV), des Future Value (FV), der internen Zinsrendite (IRR), der modifizierten internen Zinsrendite (MIRR) für periodische und datumsabhängige Zahlungen und Quittungen. Perzentile Berechnungen Berechnen Sie verschiedene Arten von Perzentilen: Median, Quartile, Quintile, Oktile, Dezile, Perzentile, jedes X.5-Perzentil, und legen Sie sie in einer Tabelle oder aktualisieren Sie ein vorhandenes Feld mit dem Datensatz Perzentilwert. Ausführen von Totals und Moving Averages Zusammenfassen eines sich bewegenden Satzes von Datensätzen, um laufende Summen zu berechnen, gleitende Mittelwerte, minimale, maximale, Bereichs-, Median-, Standardabweichung usw. Daten Normalisierung (Datentransponieren) Transponieren Sie nicht normalisierte Daten, so dass Sie leicht analysieren und pflegen können es. Regressionen Einfache, mehrfache und polynomische Regressionen mit Berechnung von Gleichungskoeffizienten, ANOVA und Resttabelle Kreuztabellen und Chi-Square Erweiterte Kreuztabellen mit Prozentsatz von Zeilen-, Spalten - und Summenwerten als Datensätze oder SpaltenMoving Average Calculation Bewegte Durchschnittsberechnung Moving Average Berechnung Ich versuche es Um einen gleitenden Durchschnitt für eine Reihe von Daten zu berechnen. Ich möchte den gleitenden Durchschnitt für jeden Punkt innerhalb der Daten generieren, um in einem Diagramm zu zeigen. Wie auch immer, unten ist ein Beispiel von MS Support. Ich habe den Brief gefolgt, aber mir gibt nicht einen gleitenden Durchschnitt. Es wiederholt den gleichen Datenpunkt über und über (der erste Datenpunkt). So glaube ich nicht, dass die Funktion das startdate in der MyRST. Seek Linie findet, also gerade die Rückgabe des ersten Datenpunktes. Schließlich (vielleicht macht dies wirklich einfach) Ich bin verwirrt darüber, wie die Indizes funktionieren. Ich dachte, Sie könnten nur einen Primärschlüssel haben, aber anscheinend können Sie mehrere Feldbeschränkungen erstellen. Ich habe versucht, dies mit der folgenden Datendefinitionsabfrage zu tun: ALTER TABLE Table1 ADD CONSTRAINT NoDupes UNIQUE (CurrencyType, TransactionDate) Sorry über die Länge dieses Beitrags. Ich schätze Ihre Hilfe. Die folgende Beispielfunktion berechnet Bewegungsdurchschnitte basierend auf einer Tabelle mit einem Mehrfachfeld-Primärschlüssel. Für dieses Beispiel werden die wöchentlichen Werte der Fremdwährungen verwendet. Gehen Sie folgendermaßen vor, um die Beispielfunktion zu erstellen: Erstellen Sie die folgende Tabelle, und speichern Sie es als Table1: Tabelle: Table1 --------------------------- -------------- Feldname: CurrencyType Primärschlüssel Datentyp: Text Feldgröße: 25 Feldname: TransactionDate Primärschlüssel Datentyp: DateTime Format: Kurzdatum Feldname: Datentyp: Währung Dezimalstellen: 4 Zeigen Sie die Tabelle in der Datenblattansicht an und geben Sie die folgenden Werte ein: CurrencyType TransactionDate Rate ------------------------------- ------------- Yen 8693 0.0079 Yen 81393 0.0082 Yen 82093 0.0085 Yen 82793 0.0088 Yen 9393 0.0091 Mark 8693 0.5600 Mark 81393 0.5700 Mark 82093 0.5800 Mark 82793 0.5900 Mark 9393 0.6000 Öffnen Sie ein neues Modul und geben Sie die folgende Funktionen: Funktion MAvgs (Perioden As Integer, Startdatum, Type-Name) Dim MyDB Als DATABASE, MyRST Als Recordset, MySum As Double Dim i, Satz x MyDB CurrentDb () Set MyRST MyDB. OpenRecordset (Tabelle 1) On Error Resume Next MyRST. Index PrimaryKey x Periods - 1 ReDim Store (x) MySum 0 Für i 0 Zu x MyRST. MoveFirst MyRST. Seek, TypeName, StartDate Diese beiden Variablen sollten in der gleichen Reihenfolge sein wie die Primärschlüsselfelder in Ihrer Tabelle. Store (i) MyRSTRate If i lt x Then StartDate StartDate - 7 Die 7 hier nimmt wöchentliche Daten 1 für Tagesdaten an. Wenn StartDate lt 8693 Dann wird MAvgs Null: Exit Function 8693 durch das früheste Datum der Daten in Ihrer Tabelle ersetzt. MySum-Speicher (i) MySum Next i MAvgs MySum-Perioden MyRST. Close-Endfunktion Erstellen Sie die folgende Abfrage auf der Grundlage der Tabelle1-Tabelle: Query: Query1 --------------------- ---------------------------------- Feld: CurrencyType Feld: TransactionDate Feld: Ratenfeld: Expr1: MAvgs (3 , TransactionDate, CurrencyType) HINWEIS: Diese Abfrage erzeugt einen dreiwöchigen gleitenden Durchschnitt der Rate-Daten. Um einen längeren oder kürzeren gleitenden Durchschnitt zu berechnen, ändern Sie die Zahl 3 in der Spalte Ausdrücke 1 von Spalte auf den Wert, den Sie berechnen möchten. Führen Sie die Abfrage aus. Beachten Sie, dass Sie die folgenden drei Wochen gleitenden Durchschnitt für jede Währung sehen. Ein Null-Wert zeigt an, dass nicht genug frühere Werte vorhanden sind, um diesen Wochenmittelwert zu berechnen. CurrencyType Transaction Rate Expr1 Mark 080.693 0,5600 Mark 081.393 0,5700 Mark 082.093 0,5800 0,57 Mark 082.793 0,5900 0,58 Mark 090.393 0.6000 0.59 Yen 080.693 0,0079 Yen 081.393 0,0082 Yen 082.093 0,0085 0,0082 Yen 082.793 0,0088 0,0085 Yen 090.393 0,0091 0,0088 RE: Moving Average Berechnung dhookom (Programmierer) 28 Jun 10 21:15 Wie alt ist dieser Code Es doesnt explizit verwenden DAO und nicht erwähnen, dass dies nicht mit verknüpften Tabellen arbeiten. Dim MyDB als DAO. Database, MyRST als DAO. Recordset. Ich würde eine Unterabfrage anstatt ein Re-Cord-Set verwenden. Es könnte etwa so aussehen: SELECT CurrencyType, Transaction, Rate (SELECT Avg (Rate) FROM Tabelle1 B WHERE A. CurrencyType B. CurrencyType UND A. TransactionDate ZWISCHEN B. TransactionDate - 14 UND B. TransactionDate) FROM Tabelle1 A RE: Umzug Durchschnittliche Berechnung Das ist wirklich perfekt. Ich schätze deine Hilfe sehr. Allerdings ist der Code, den Sie gaben die Berechnung der vorwärts 14 Tage gleitenden Durchschnitt (Platzierung der gleitenden Durchschnitt in den Datensatz für Tag 1 des Durchschnitts, wo ich wollte, dass es ein rückwärts gerichteter Durchschnitt, platziert in Rekord 14). Ich änderte nur etwas zu den folgenden und es scheint zu funktionieren SELECT A. CurrencyType, A. TransactionDate, A. Rate, (SELECT Avg (Rate) FROM Tabelle1 B WHERE A. CurrencyType B. CurrencyType UND B. TransactionDate ZWISCHEN A. TransactionDate - 14 AND A. TransactionDate) AS Expr1 FROM Tabelle1 AS Wie Sie sehen können, war alles, was ich tat Austausch A für B in der where-Klausel. Dies ist eine wirklich große Hilfe für mich und ich schätze es wirklich. Ich habe nicht gesehen Codierung wie diese vor, und ehrlich, ich nicht wirklich verstehen. Ich weiß nicht, wie die SQL versteht, was B und A sind. Ich gehe davon aus, dass sie eine Art von alternativen Verweis auf Tabelle1 erstellen. Wenn Sie irgendeine Anleitung geben können, würde ich es wirklich schätzen. Auch, vielleicht ein Hinweis auf Material, das ich sehen konnte bin ich immer sehr aufgeregt, um etwas Neues über VBASQL lernen, und ich wirklich schätzen Ihre Hilfe RE: Moving Average Calculation PHV (MIS) 29 Jun 10 12:22 versteht, was B und A Sind sie alias es RE: Moving Average Calculation Vielen Dank, PHV. Es macht besser Sinn bereits RE: Moving Average Berechnung joshery420 (TechnicalUser) 6 Jul 10 15:06 Wow, nie sah SQL-Sicht vor. Äußerst hilfreich. Ich versuche, diesen Code zu bekommen, um in meinem eigenen Datensatz zu funktionieren und ich bin auf eine bestimmte Frage geheilt. Pd2004, nicht sicher, ob der neue Unterabfrage-Code arbeitete die gleiche wie Ihre alten VBA-Code oder nicht, aber mit meinen Daten zeigt es immer noch den gleitenden Durchschnitt, auch wenn es arent genug Tage, um die Länge eines durchschnittlichen erstellen. z. B. Wenn Im einen 7-Tage-Rolling-Durchschnitt durchführt, zeigt Tag 1 dieselben Daten in der Spalte 7DayAvg wie in der Tagesdatenspalte an. Tag 2 würde zeigen, den Durchschnitt der Tage 1 und 2, etc. Einer von euch Jungs wissen, wie man dies durch Zufall zu beheben Auch danke für die große Code-Tipp PHV. RE: Verschieben der Mittelwertberechnung joshery420 (TechnicalUser) 6 Jul 10 15:08 Woops, gemeint zum Dank dhookom für den Code-Tipp, nicht PHV. Aber hey, danke euch beiden. XD RE: Moving Average Calculation Ich werde die besten Lösungen für die Fachleute hier verlassen, aber Sie können in meinem ursprünglichen Post sehen, wie das Microsoft-Hilfe-Beispiel versucht, das zu behandeln. Hier ist der Code: Wenn StartDate lt 8693 Dann MAvgs Null: Exit Function 8693 wird durch das früheste Datum der Daten in Ihrer Tabelle ersetzt. Sie sind nur verlassen die Funktion, wenn das Datum nicht die Kriterien passt. Ich weiß nicht, ob Sie so etwas in den Alias-Code von dhookem zur Verfügung stellen könnte. Ich dont wie ihre Art, dies zu behandeln, und ich vermute, dass dhookem wird eine viel elegantere Lösung. Für meine Zwecke die Frage, die Sie beschreiben, ist nicht ein Problem, aber ich werde daran interessiert, keine Lösungen zu sehen. RE: Moving Average Berechnung Dhookom (Programmer) 6 Jul 10 17:05 Sie könnten versuchen, mit IIf (), um für eine Zählung der Anzahl der Datensätze zu testen. Achtung: es wird ein nicht getestetes Notepad-Code ausgeführt: SELECT A. CurrencyType, A. TransactionDate, A. Rate, IIF (SELECT Count (Rate) FROM Tabelle1 C WHERE A. CurrencyType C. CurrencyType AND C. TransactionDate BETWEEN A. TransactionDate - 14 AND A. TransactionDate), NULL) AS Expr1 FROM Tabelle1 AS A RE: Gleitende Durchschnittsberechnung

No comments:

Post a Comment