Thoughts from Dan Miser RSS 2.0
 Thursday, January 12, 2006
I had a need to write SQL to answer the question "How many times in a row have I scored -20 or better?" in a game of Golden Tee. I have the raw data stored in a table that has these fields (and more, but they aren't important to this exercise).


tblContestResults
ContestId    Long Integer
Score        Integer

I didn't want to use a cursor, and I wanted to stay as close to ANSI SQL as possible (so no stored procs, etc.). After googling around a bit, I came across this link that showed how to do this all in SQL using nested selects and virtual groups. The sample was written to be compatible with MSSQL. After tweaking it just a bit, I came to this solution, which works wonderfully.


SELECT Max(grpCnt) AS MaxRun
FROM (Select grp, Count(*) As GrpCnt 
  From 
  (Select A.ContestId,  A.Score, 
       Case 
           When A.Score <= -20  Then 
                    Isnull( (Select Max(B.ContestId) From tblContestResults As B 
                                Where B.ContestId < A.ContestId and B.Score>-20), 
                               (Select Min(C.ContestId) from tblContestResults AS C) ) 
      End As grp 
  From tblContestResults As A) As WithGrps 
  Where grp Is Not Null 
 Group By grp) AS WithGrpCnts;

You can take each of the nested selects out and break them apart to execute them in order to see how the query is built up. Quite an interesting technique, and one that I will definitely keep in my bag of tricks. For my purposes, I had to use MS Access, so that meant I had to change things in the SQL a bit more since there is no "CASE WHEN" in Access. The following is the code I ended up using, and it also works quite well. I didn't use the nz() function because there is a problem in Delphi's TADODataset when executing code that has that expression in it (more on that later). Using nz() does work in Access, and makes the query easier to read, IMO. But if it doesn't work in Delphi, then I can't use it.


SELECT MAX(grpCnt) AS MaxRun
FROM (SELECT grp, Count(*) as GrpCnt
  FROM
  (SELECT A.ContestID, A.Score, 
    IIf(A.Score<=-20,
      IIf(
        isnull((Select Max(B.ContestId) From tblContestResults As B Where B.ContestId < A.ContestId and B.Score>-20))
        ,(Select Min(C.ContestId) from tblContestResults AS C)
        ,(Select Max(B.ContestId) From tblContestResults As B Where B.ContestId < A.ContestId and B.Score>-20)
      )
  ,Null) AS grp
  FROM tblContestResults AS A
  ORDER BY ContestId) as WithGrps
WHERE grp is not null
GROUP BY grp) AS WithGrpCnts;
Thursday, January 12, 2006 9:03:00 AM (Central Standard Time, UTC-06:00)  #    Comments [0] -
Delphi
Tracked by:
http://9nh-information.info/81809606/specialty-watches.html [Pingback]
http://9nc-information.info/91941314/index.html [Pingback]
http://9nr-information.info/31542509/index.html [Pingback]
http://9nt-information.info/95233167/book-group-guide-to-the-education-of-little... [Pingback]
http://9ne-information.info/37214100/index.html [Pingback]
http://9nh-information.info/26122845/index.html [Pingback]
http://9nt-information.info/99935916/index.html [Pingback]
http://9nj-information.info/99584373/index.html [Pingback]
http://9ou-information.info/70169406/napa-valley-real-estate-companies.html [Pingback]
http://9qk-information.info/04743199/index.html [Pingback]
http://9ot-information.info/38669337/index.html [Pingback]
http://9oc-information.info/92009136/index.html [Pingback]
http://9qm-information.info/80737209/index.html [Pingback]
http://9ol-information.info/78591606/index.html [Pingback]
http://9ov-information.info/33225066/grandpop-handyman-gifts.html [Pingback]
http://9ov-information.info/90446774/index.html [Pingback]
http://9ou-information.info/16379769/index.html [Pingback]
http://9rj-information.info/56493999/hyde-racing.html [Pingback]
http://9rq-information.info/02019938/internet-express-isp.html [Pingback]
http://9sf-information.info/36846879/index.html [Pingback]
http://9sk-information.info/73536561/index.html [Pingback]
http://9ro-information.info/06667811/index.html [Pingback]
http://9rc-information.info/95745162/market-analysts-directory.html [Pingback]
http://9rx-information.info/52958500/index.html [Pingback]
http://9rq-information.info/26038999/index.html [Pingback]
http://9rk-information.info/87069566/index.html [Pingback]
http://9rr-information.info/87492684/index.html [Pingback]
http://9rr-information.info/10553788/index.html [Pingback]
http://9sm-information.info/51789880/sikh-names-for-babies.html [Pingback]
http://9sm-information.info/37463952/endowment.html [Pingback]
http://9sk-information.info/31255425/hometown-aol-com-bdsm-bdsm-anima.html [Pingback]
http://9ri-information.info/59552263/index.html [Pingback]
http://9rh-information.info/90890052/index.html [Pingback]
http://9sh-information.info/77812420/graduatorie-2006-2007.html [Pingback]
http://9sd-information.info/95950613/lcd-hdmi-26-pollici.html [Pingback]
http://9sr-information.info/40076226/index.html [Pingback]
http://9rg-information.info/67015503/sirius-satelllite-radio-repeaters.html [Pingback]
http://9ri-information.info/96763782/index.html [Pingback]
http://9rv-information.info/04624833/index.html [Pingback]
http://9uafa-le-informazioni.info/87166122/concerti-veneto.html [Pingback]
http://9uaeb-le-informazioni.info/33004102/index.html [Pingback]
http://9uaea-le-informazioni.info/71754376/index.html [Pingback]
http://9uafb-le-informazioni.info/85404142/index.html [Pingback]
http://9uaei-le-informazioni.info/68988456/index.html [Pingback]
http://9uafa-le-informazioni.info/53578010/programma-d-d-t-fattura-gratis.html [Pingback]
http://9uaeb-le-informazioni.info/64741564/mykonos-locali.html [Pingback]
http://9uaeg-le-informazioni.info/94434006/index.html [Pingback]
http://9uaek-le-informazioni.info/32560749/index.html [Pingback]
http://9uaes-le-informazioni.info/38464910/index.html [Pingback]
http://9uaei-le-informazioni.info/16989705/aircraft-lease-back.html [Pingback]
http://9uaec-le-informazioni.info/65785574/tri-nations.html [Pingback]
http://9uafg-le-informazioni.info/25138918/index.html [Pingback]
http://9uaep-le-informazioni.info/91399599/motorino-assicurazione.html [Pingback]
http://9uaef-le-informazioni.info/07882252/index.html [Pingback]
http://9uafl-le-informazioni.info/22433654/club-auto-moto-storica-napoli.html [Pingback]
http://9uafg-le-informazioni.info/25256147/index.html [Pingback]
http://9uaeb-le-informazioni.info/29783133/secondamedicina-com-terapia-diabete-h... [Pingback]
http://9uaes-le-informazioni.info/89791004/memphis-amerisuites-memphis-cordova.h... [Pingback]
http://9uafi-le-informazioni.info/80036708/grafico-a-torta.html [Pingback]
http://9uafk-le-informazioni.info/89979253/buenos-aires-feria-de-mataderos.html [Pingback]
http://9uafd-le-informazioni.info/40477804/index.html [Pingback]
http://9uaej-le-informazioni.info/42354150/index.html [Pingback]
http://9uaet-le-informazioni.info/94697309/index.html [Pingback]
http://9uafr-le-informazioni.info/82051957/index.html [Pingback]
http://9uaep-le-informazioni.info/66869590/index.html [Pingback]
http://9uahl-le-informazioni.info/91232481/index.html [Pingback]
http://9uagc-le-informazioni.info/92470986/index.html [Pingback]
http://9uahi-le-informazioni.info/50626897/lubamba-silvye.html [Pingback]
http://9uagl-le-informazioni.info/20164831/index.html [Pingback]
http://9uahe-le-informazioni.info/46009524/beretta-calibro-20.html [Pingback]
http://9uagl-le-informazioni.info/96077184/white-christmas-the-drifters.html [Pingback]
http://9uagp-le-informazioni.info/01114495/lander-caravan.html [Pingback]
http://9uahd-le-informazioni.info/64313529/marrazzi-ceramica.html [Pingback]
http://9uagh-le-informazioni.info/12484298/fotografia-storica-torino-ferrovia.ht... [Pingback]
http://9uagf-le-informazioni.info/88681844/index.html [Pingback]
http://9uago-le-informazioni.info/05748746/part-time-work.html [Pingback]
http://9uagh-le-informazioni.info/85838116/index.html [Pingback]
http://9uagj-le-informazioni.info/51856506/loal.html [Pingback]
http://9uagn-le-informazioni.info/57755971/drum-toner-fotocopiatrice-lexmark.htm... [Pingback]
http://9uagm-le-informazioni.info/31809835/linea-prestito-online.html [Pingback]
http://9uagb-le-informazioni.info/63637874/index.html [Pingback]
http://9uagg-le-informazioni.info/11117514/index.html [Pingback]
http://9uaha-le-informazioni.info/81416655/glass-door.html [Pingback]
http://9uagd-le-informazioni.info/69174476/index.html [Pingback]
http://9uagr-le-informazioni.info/07450547/pittori-arte-contemporanea.html [Pingback]
http://9uagf-le-informazioni.info/75363155/offerte-disneyland-paris.html [Pingback]
http://9uahm-le-informazioni.info/99784727/index.html [Pingback]
http://9uahh-le-informazioni.info/52913224/guglielmo-secondo.html [Pingback]
http://9uago-le-informazioni.info/82609341/acm-90.html [Pingback]
http://9uahs-le-informazioni.info/36029405/index.html [Pingback]
Navigation
Archive
<August 2008>
SunMonTueWedThuFriSat
272829303112
3456789
10111213141516
17181920212223
24252627282930
31123456
About the author/Disclaimer

Disclaimer
The opinions expressed herein are my own personal opinions and do not represent my employer's view in any way.

© Copyright 2008
Dan Miser
Sign In
Statistics
Total Posts: 306
This Year: 21
This Month: 0
This Week: 0
Comments: 604
All Content © 2008, Dan Miser
DasBlog theme 'Business' created by Christoph De Baene (delarou)