418342 ภาคปลาย 2552/การบ้าน 1

จาก Theory Wiki
ไปยังการนำทาง ไปยังการค้นหา

ให้เมื่อวันที่ 11 กุมภาพันธ์ 2553 ส่งวันที่ 17 กุมภาพันธ์ 2553 เวลา 23.59 น.

ในการบ้านนี้คุณจะอ่านข้อมูลจาก Freebase แล้วนำมาสร้างฐานข้อมูลอย่างๆ ง่ายๆ พร้อมกับทำหน้าเว็บให้สามารถค้นหาข้อมูลเหล่านี้ได้

เริ่มต้น

หา database dump ของหัวข้อที่คุณสนใจจาก http://download.freebase.com/datadumps/2009-12-30/browse/ ให้เลือกไฟล์ .tsv จากในนั้นมาหนึ่งไฟล์ ไฟล์ที่คุณเลือกควรจะมี

  • ฟีลด์ (คอลัมน์) อย่างน้อย 5 ฟีลด์
  • เรคอร์ด (แถว) อย่างน้อย 500 แถว

สร้างแอพพลิเคชัน

สร้างแอพพลิเคชันในลักษณะเดียวกันกับ ปฏิบัติการที่ 5 โดยทำตามขั้นตอนนี้

  • สร้าง scaffold ของโมเดลของหัวข้อที่คุณเลือก ยกตัวอย่างเช่น ถ้าผมเลือกหัวข้อเกี่ยวกับภาษาโปรแกรม (computer/programming_language.tsv) ผมอาจจะสร้าง scaffold ดังต่อไปนี้
> ruby script/generate scaffold programming_language name:string language_paradigms:string ...
  • สร้าง migration สำหรับเพิ่มข้อมูลเข้าฐานข้อมูล เช่น
> ruby script/generate migration add_programming_languages
  • copy ไฟล์ .tsv ที่คุณโหลดมาไปใส่ใน directory db/migrate
  • เติม migration ที่คุณเพิ่งสร้าง ให้ฟังก์ชัน up ทำการอ่านไฟล์ .tsv ที่คุณโหลดมา และฟังก์ชัน down ทำการลบเรคอร์ดทุกตัวออกให้หมด กล่าวคือไฟล์ migration ที่สร้างอาจจะมีหน้าตาเป็นอย่างนี้

<geshi lang="rails"> class AddProgrammingLanguages < ActiveRecord::Migration

 def self.up
   ... (เติมโค้ดส่วนนี้เอาเอง)
 end
 def self.down
   ProgrammingLanguage.destroy_all
 end

end </geshi>

  • สร้าง action ชื่อ search ใน controller ให้รับ parameter ลักษณะเดียวกันกับหน้า search ในปฏิบัติการที่ 5 แต่คราวนี้ให้ผู้ใช้กำหนดค่าฟีลด์ได้อย่างน้อยสามฟีลด์ขึ้นไป
  • หลังจากทำการพัฒนาเสร็จแล้ว ให้ rollback migration ทั้งหมด (ให้ database ว่าง) แล้ว zip ไดเรคทอรีที่ rails สร้างทั้งหมดส่งมาที่อีเมล์ของ อ.ประมุข (pramook at gmail dot com) และ อ.ชาคริต (chakrit dot w at gmail dot com)