J'ai un problème avec SQL. J'ai le tableau suivant:Rotation des clients dans SQL Server 2014
declare @t table (date datetime,
shop VARCHAR(50),
client VARCHAR(50)
);
insert into @t
VALUES ('2016-01-15', 'abc','a1'),
('2016-01-15', 'abc','b1'),
('2016-01-15', 'def','c1'),
('2016-01-15', 'def','a1'),
('2016-01-15', 'ghi','b1'),
('2016-01-15', 'ghi','a1'),
('2016-02-15', 'abc','a1'),
('2016-02-15', 'abc','b1'),
('2016-02-15', 'abc','c1'),
('2016-02-15', 'def','a1'),
('2016-02-15', 'ghi','b1'),
('2016-02-15', 'ghi','a1'),
('2016-03-15', 'abc','a1'),
('2016-03-15', 'abc','c1'),
('2016-03-15', 'def','a1'),
('2016-03-15', 'ghi','b1'),
('2016-03-15', 'ghi','e1')
Je voudrais calculer la rotation du client. Donc, pour chaque mois, pour chaque magasin, il faut compter le nombre de clients qui sont arrivés, et combien de clients sont restés comme le mois précédent. Je ne peux pas simplement regarder le nombre de clients, mais je dois vérifier si le nom spécifique du client est apparu un mois plus tôt. Toutes les dates ressemblent à ceci: "année-mois-15".
Je voudrais obtenir le tableau comme suit:
declare @t2 table (date date,
shop VARCHAR(50),
churned INTEGER,
stayed INTEGER,
came INTEGER
);
INSERT INTO @t2
VALUES ('2016-02-15', 'abc', 0, 2, 1),
('2016-02-15', 'def', 1, 1, 0),
('2016-02-15', 'ghi', 0, 2, 0),
('2016-03-15', 'abc', 1, 2, 0),
('2016-03-15', 'def', 0, 1, 0),
('2016-03-15', 'ghi', 1, 1, 1)
Ainsi, par exemple pour le magasin abc après le premier mois 0 clients brassés, 2 clients sont restés comme mois avant et 1 nouveau client est venu. Baratté signifie que le client est parti.
Merci pour votre aide. J'utilise SQL Server 2014
EDIT: Un autre exemple: Pour ces données:
declare @t table (date datetime,
shop VARCHAR(50),
client VARCHAR(50)
);
insert into @t
VALUES ('2016-01-15', 'abc','a1'),
('2016-01-15', 'abc','b1'),
('2016-02-15', 'abc','b1'),
('2016-02-15', 'abc','c1'),
('2016-03-15', 'abc','z1'),
('2016-03-15', 'abc','y1'),
('2016-03-15', 'abc','a1')
je devrais obtenir le tableau suivant:
declare @t2 table (date date,
shop VARCHAR(50),
churned INTEGER,
stayed INTEGER,
came INTEGER
);
INSERT INTO @t2
VALUES
('2016-01-15', 'abc', 0, 0, 2),
('2016-02-15', 'abc', 1, 1, 1),
('2016-03-15', 'abc', 2, 0, 3)
C'est par exemple simple avec une seule magasiner pour une clarification.
définissent "baratte" s'il vous plaît. – Tanner
Cet homme que le client a quitté. –