sql >> Database teknologi >  >> RDS >> Mysql

Udførelse af en lagret procedure med markør i PHP

Baseret på diskussioner i chat for 3 grupperinger, og dette gav SQLFiddle for testdata (ikke meget data der).

På grund af test af data med et glidende vindue hvor now() er i relation til disse data, blev følgende variabel brugt til at "fryse" now() . Simpelthen for at lette test og verifikation af output.

Så forlad det i sidste ende og skift de 4 referencer i koden, der bruger det (bemærk, at gruppe 3 bruger det to gange).

now() variabel:

select @theNow:=now();
-- REM OUT the following line. It is used only for testing (as now will chg, your data won't)
select @theNow:='2016-06-23 14:00:00';

Forespørgslen:

select id,sentNum,message,sentTime,startAtTime,sentByTime,msgType,theGrp from
(   select id,sentNum,message,sentTime,startAtTime,sentByTime,msgType,theGrp,
    if([email protected],greatest(@sentNumChg:=1,0),least(@sentNumChg:=0,1)) as dummy1,
    if([email protected],greatest(@grpChg:=1,0),least(@grpChg:=0,1)) as dummy2,
    if(@sentNumChg=1 or @grpChg=1,@seqNum:=1,@seqNum:[email protected]+1) as seqNum,
    @lastSentNum:=sentNum as setLast01,
    @lastGrp:=theGrp as setLast02
    from
    (   -- GROUP 1: sentByTime<=now(), INVITE
        select `id`, `sentNum`, `message`, `sentTime`, `startAtTime`, `sentByTime`, `msgType`, 1 as theGrp
        from SmsQueue
        where sentByTime<[email protected] and msgType='invite'
        UNION ALL
        -- GROUP 2 startAtTime<=now(), BROADCAST
        select `id`, `sentNum`, `message`, `sentTime`, `startAtTime`, `sentByTime`, `msgType`, 2 as theGrp
        from SmsQueue
        where startAtTime<[email protected] and msgType='broadcast'
        UNION ALL
        -- GROUP 3: sentByTime>now() && startAtTime<=now(), INVITE
        select `id`, `sentNum`, `message`, `sentTime`, `startAtTime`, `sentByTime`, `msgType`, 3 as theGrp
        from SmsQueue
        where sentByTime>@theNow and startAtTime<[email protected] and msgType='invite'
    ) d1
    cross join (select @sentNumChg:=0,@grpChg:=0,@lastSentNum:='',@lastGrp:=0,@seqNum:=0) as xParams
    order by sentNum,theGrp,sentByTime,id -- id is the tie-break
) d2
where (theGrp=1 and seqNum<3) or (theGrp=2 and seqNum=1) or (theGrp=3 and seqNum=1)
order by sentNum,theGrp;

Output (mit klientværktøj er tekstudfordret i øjeblikket):

Se mine generelle kommentarer øverst i dette mit svar for avanceret variabel brug.




  1. Vil du opdatere flere rækker med én forespørgsel?

  2. Hvordan henter man datoen for mms fra content://mms.

  3. Fjerner MySQL 5.7 fuldstændigt

  4. Avanceret SQL:Indsæt output fra den parametriserede tabelværdi-funktion i SQL-tabel