התמריץ
כשהיייתי איש נתונים (data scientist) ב-Quora, אנשים נהגו לשאול אותי בנוגע למשאבים ללימוד SQL. התאמצתי למצוא משהו שארגיש נח להמליץ עלייו, מפני שלהבנתי מקור טוב צריך להיות חינמי, ללא צורך בהרשמה ולקחת בחשבון את הפדגוגיה המתאימה—הוא צריך לדאוג למשתמשים שלו ולא היה שום דבר כזה בסביבה.
אנ מאמין ש Select Star SQL עומד ביעדים הללו, בזכות התמודדות עם כמה מכשולים טכניים. אני מקווה שבדומה למה שLearn You a Haskell for Great Good! ו-Beautiful Racket עשו עבור Haskell ו-Racket,
Select Star SQL יהפך למקום הטוב ביותר באינטרנט ללמוד בו SQL.
הפדגוגיה
אלו העקרונות שהנחו את העיצוב של הפרוייקט:
-
הדרך הטובה ביותר ללמוד תכנות היא עשייה.
חלק גדול כולל תרגילים. המאמץ להתמודד איתם אומר לדרוש את רוב הזמן. -
התרגילים צריכים להיות מציאותיים וממשיים.
כמו שאמר אלן קיי (Alan Kay): "לעולם לא תתנו [למי שלומד/ת] לעשות משהו שהוא לא הדבר האמיתי— אבל תהיו חייבים לקרוע ת’תחת כדי להבין מהו הדבר הממשי בהקשר של דרך החשיבה שלהם בשלב ההתפתחות בו הם נמצאים.”בדומה, התרגילים כאן עוצבו כדי להציג רמת תחכום עולה של טכניקות SQL תוך כדי חקר של סט הנתונים בדרכים שבהן אנשים יעשו בפועל.
-
לימוד תכנות הן לימוד של צורת חשיבה.
המטרה שלנו כאן היא לא ללמד אתכם את הכללים לשימוש ב-GROUP BY
או מתי להעדיףLEFT JOIN
על פניINNER JOIN
. נדע שעמדנו ביעד שלנו אם אחרי שכתבתם שאילתת SQL תוכלו לעצום את העיניים ולדמיין מה המחשב עושה ומה התוצאה שהוא עומד להציג. רק אז תהיו מסוגלים להשתמש ב-SQL כדי לפתור בעיות בעולם האמיתי.
סט הנתונים
סט הנתונים שלנו מתעד את הנידונים למוות בטקסס שהוצאו להורג משנת 1976, השנה בה החזיר בית המשפט העליון האמריקני את עונש המוות לתוקפו, ועד להווה. המידע חולץ מאתר מחלקת המשפט הפלילי בטקסס (Texas Department of Criminal Justice) באמצעים אוטומטיים, כשניתן היה. עם זאת, חלק גדול מהמידע עד לשנת 1995 זמין רק כצילומים של מסמכים מודפסים, מה שדרש חילוץ נתונים ידני ומייסר.
המידע הגולמי זמין כקובץ csv להורדה. בזכות חילוץ הנתונים הידני וניקוי הנתונים, מדובר כנראה בסט הנתונים השלם ביותר בנושא עונש המוות באינטרנט. אתם יכולים לחקור גם את החלק ממנו שהוכן עבור הספר הזה
במובן מסויים, המידע הוא סתם עוד חלק משעמם בספר תכנות. במובן אחר, כל שורה מייצגת סבל עצום, אובדן חיים ובכמה מקרים קבלה ונחמה. בהכנת סט הנתונים הזה התרגשתי מאוד ממספר ההצהרות שלפני ההוצאה להורג ומצאתי את עצמי בוחן מחדש את עמדתי ביחס לעונש המוות. אני מקווה שכשנבחן את הנתונים תהרהרו גם אתם לעומק בנושא.
העניינים הטכניים
-
בסיס נתונים בצד לקוח (Client-Side Databases. אחד האתגרים בליצור את האתר הזה כאתר בחינם היה ההמנעות מתשלום עבור אירוח (web hosting). אולם, כדי לאפשר למשתמשים התנסות מעשית עם בסיס נתונים (ראו הפדגוגיה), יש צורך לארח ולשלם על צד שרת מתאים. למרבה השמחה, יש דבר כזה בסיסי נתונים בצד לקוח. זה איפשר לי להשתמש בשירות אירוח העמודים הסטטיים החינמי שלGithub Pages ולבנות את הדפים באתר כך שיריצו בסיס נתונים של SQLite על הדפדפן שלכם. אלון זקאי (Alon Zakai) ואחרים הפכו את זה לאפשר כשהעבירו את הקוד של SQLite C ל-Javascript באמצעות Emscripten.
-
פגשתי את (Matthew Butterick) מתיו בוטריק ב-Racket Summer School ופשוט התפוצצתי מהעבודה הנהדרת שהוא עשה ב-Beautiful Racket וב- Practical Typography. כמו שבטח שמתם לב, אימצתי הרבה רעיונות עיצוביים משם.
-
Jekyll. אלמלא Jekyll, הייתי חייב לכתוב את כל ה-html של האתר הזה בצורה ידנית. תודה לאל על Jekyll.
-
התאפשר לי לעשות שימוש חוזר בהרבה מהקוד בכך שכתבתי רכיבים של תרגול ובוחן כמו תגיות html מותאמות (custom html tags) . עד כמה שאני מבין זהו פיתוח חדיש יחסית ואני מקווה שה-W3C ימשיך לעודד לאימוץ רחב יותר שלו.
צרו קשר
-
לתיקונים והצעות, כתבו לי (Kao) ב-zichongkao@gmail.com. ניתן ללמוד עלי פרטים נוספים ב-Kaomorphism.
-
להערות והצעות בנוגע לתרגום העברי, או לסיוע בהוספת תרגומים לשפות נוספות, ניתן ליצור קשר עם הפיץ באתר, במייל (noam@thepitz.io) או בטוויטר (pitz_the@).