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]
Comments are closed.
Navigation
Archive
<October 2008>
SunMonTueWedThuFriSat
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678
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: 310
This Year: 25
This Month: 1
This Week: 0
Comments: 605
All Content © 2008, Dan Miser
DasBlog theme 'Business' created by Christoph De Baene (delarou)