SQL-запрос для условного подведения итогов на основе движущегося окна даты

Я пытаюсь выяснить некоторую статистику раздвижного окна на своих пользователях. У меня есть таблица с пользователем и столбцы, такие как created_at и verified_at. В течение каждого месяца я хотел бы узнать, сколько зарегистрированных пользователей (простая группа date_trunc created_at), и затем тех людей, сколько проверенный в моем раздвижном окне (называют это 60 днями).

Я хотел бы сделать SQL-запрос, который дает мне что-то как:

Month    | Registered | Verified in 60 days
Jan 2009 | 1543       | 107
Feb 2009 | 2000       | 250

Я использую postgresql. Я запуск, смотрящий на сумму (случай...), но я не знаю, могу ли я заставить свой случай зависеть от date_trunc так или иначе.

Это не работает, конечно, но здесь является идеей:

SELECT DATE_TRUNC('month', created_at) as month, 
COUNT(*) as registered,
SUM(CASE WHEN verified_at < month+60 THEN 1 ELSE 0 END) as verified
FROM users
GROUP BY DATE_TRUNC('month', created_at)
18
задан teich 11 January 2010 в 22:44
поделиться

3 ответа

SELECT  COUNT(created_at) AS registered,
        SUM(CASE WHEN verified_at <= created_at + '60 day'::INTERVAL THEN 1 ELSE 0 END) AS verified
FROM    generate_series(1, 20) s
LEFT JOIN
        users
ON      created_at >= '2009-01-01'::datetime + (s || ' month')::interval
        AND created_at < '2009-01-01'::datetime + (s + 1 || ' month')::interval
GROUP BY
        s
25
ответ дан 30 November 2019 в 08:33
поделиться

В аналогичном сценарии я видел, что конкретные параметры приложения могут быть предоставлены программно при создании экземпляра приложения. Это помогло разместить параметры, связанные с конфигурацией, в файле config.ini

. На самом деле я сделал это следующим образом:

в файле index.php, чтобы загрузить приложение

     $application = new Zend_Application(APPLICATION_ENV, array(
                'resources' => array(
                   'FrontController' => array(
                       'controllerDirectory' => APPLICATION_PATH . '/main/controllers',
                    ),
                'layout' => array(
                    'layoutpath' => APPLICATION_PATH . "/layouts/scripts"
                    ),
                ),
            ));

and then inside the bootstrap parse the config.ini inidependently

    protected function _initConfigFile() {
        try {
            $configuration = new Zend_Config_Ini(
                APPLICATION_PATH . '/config/app.ini',
                APPLICATION_ENV );
            $registry->configuration = $configuration;
        } catch (Zend_Exception $zExp) {
            echo "Could not read application ini file (app.ini). "
                . " Please check that it exists and has the appropriate structure.\n";
            echo("\n");
            var_dump($zExp);
            exit(1);
        }
    }

в bootstrap

-121--4577998-

скачать с pastebin

System.out.println((new URL("http://pastebin.com/pastebin.php?dl=f722c7eb0")).getContent())
-121--1851157-
SELECT
    MONTH,
    COUNT(*) AS Registered,
    SUM (CASE WHEN datediff(day,reg_date,ver_date) < 60 THEN 1 ELSE 0) as 'Verified in 60 //days datediff is an MSSQL function amend for postgresql'
FROM
    TABLE
GROUP BY
    MONTH
0
ответ дан 30 November 2019 в 08:33
поделиться

Как указывает Габриэль, использование SSMA является лучшим решением для увеличения размеров таблиц, индексов и взаимосвязей в Access. Тогда я бы предложил работать над интерфейсом Access, содержащим запросы, формы, отчеты, макросы и код VBA, чтобы он работал с местом хранения данных SQL Server. Это не займет много времени при сравнении, чтобы переписать приложение.

Тогда вы можете обнаружить, что вам не нужно переписывать приложение в другой среде. Это предполагает правильную нормализацию и чистоту таблиц. Даже тогда в Access может быть проще провести некоторую очистку в этом отношении.

-121--4780379-

Циклические зависимости являются занозой в заднице и должны устраняться везде, где это возможно. В дополнение к предложениям форвардной декларации, приведенным до сих пор (Alok's - лучший пример), я хотел бы внести в работы еще одно предложение: разорвать взаимную зависимость между Board и Move, введя третий тип (назовите его BoardMireAssoc для иллюстрации; Уверен, можно придумать менее отстой название):

#ifndef H_BOARD_MOVE_ASSOC
#define H_BOARD_MOVE_ASSOC

#include "Move.h"
#include "Board.h"

struct BoardMoveAssoc {
    Move m;
    Board b;
};

...
#endif

По этой схеме Board и Move не должны ничего знать друг о друге; любые связи между ними управляются типом BoardMeyAssoc. Точная структура будет зависеть от того, как предполагается соотносить переезд и Правление; Например, если несколько перемещений отображаются на одну плату, структура может выглядеть более похожей на

 struct BoardMoveAssoc {
     Move m[NUM_MOVES] // or Move *m;
     Board b;
 };

Таким образом, вам не нужно беспокоиться о объявлениях вперед или неполных типах. Вы вводите третий тип в смесь, но я верю, что это будет легче понять и поддерживать.

-121--3815283-

возможно, вы могли бы объединить различные месяцы.

select sum(whatever), 'january' from user where month = 'january'
union all
select sum(whatever), 'february' from user where month = 'february'
...
0
ответ дан 30 November 2019 в 08:33
поделиться
Другие вопросы по тегам:

Похожие вопросы: