ผลต่างระหว่างรุ่นของ "418342 ภาคปลาย 2553/การบ้าน 2"
ไปยังการนำทาง
ไปยังการค้นหา
Ckw (คุย | มีส่วนร่วม) |
Ckw (คุย | มีส่วนร่วม) |
||
แถว 49: | แถว 49: | ||
<tr> | <tr> | ||
<td>50040229</td> | <td>50040229</td> | ||
− | <td> | + | <td>20</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td> | <td> | ||
* -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | * -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | ||
แถว 63: | แถว 63: | ||
<tr> | <tr> | ||
<td>50042993</td> | <td>50042993</td> | ||
− | |||
− | |||
− | |||
− | |||
<td>0</td> | <td>0</td> | ||
− | <td> | + | <td>0</td> |
+ | <td>0</td> | ||
+ | <td>0</td> | ||
+ | <td>0</td> | ||
+ | <td>0</td> | ||
<td> | <td> | ||
* -8 เนื่องจากมีเพียง 113 record | * -8 เนื่องจากมีเพียง 113 record | ||
แถว 78: | แถว 78: | ||
<tr> | <tr> | ||
<td>50043058</td> | <td>50043058</td> | ||
− | |||
− | |||
− | |||
− | |||
<td>0</td> | <td>0</td> | ||
− | <td> | + | <td>0</td> |
+ | <td>0</td> | ||
+ | <td>0</td> | ||
+ | <td>0</td> | ||
+ | <td>0</td> | ||
<td> | <td> | ||
* -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | * -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | ||
แถว 92: | แถว 92: | ||
<tr> | <tr> | ||
<td>50043082</td> | <td>50043082</td> | ||
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td></td> | <td></td> | ||
</tr> | </tr> | ||
แถว 103: | แถว 103: | ||
<tr> | <tr> | ||
<td>50043140</td> | <td>50043140</td> | ||
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td> | <td> | ||
* -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | * -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | ||
แถว 116: | แถว 116: | ||
<tr> | <tr> | ||
<td>50043173</td> | <td>50043173</td> | ||
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td> | <td> | ||
* -20 เนื่องจากไม่อนุญาตให้ผู้ใช้ search เงื่อนไขหลายๆ เงื่อนไขพร้อมๆ กัน | * -20 เนื่องจากไม่อนุญาตให้ผู้ใช้ search เงื่อนไขหลายๆ เงื่อนไขพร้อมๆ กัน | ||
แถว 129: | แถว 129: | ||
<tr> | <tr> | ||
<td>50043215</td> | <td>50043215</td> | ||
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td> | <td> | ||
* -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | * -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | ||
แถว 143: | แถว 143: | ||
<tr> | <tr> | ||
<td>50043231</td> | <td>50043231</td> | ||
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td> | <td> | ||
* -2 เนื่องจากมีเพียงแค่ 4 ฟีลด์ | * -2 เนื่องจากมีเพียงแค่ 4 ฟีลด์ | ||
แถว 158: | แถว 158: | ||
<tr> | <tr> | ||
<td>50043306</td> | <td>50043306</td> | ||
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td> | <td> | ||
* -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | * -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | ||
แถว 193: | แถว 193: | ||
<tr> | <tr> | ||
<td>51180198</td> | <td>51180198</td> | ||
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td> | <td> | ||
* -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | * -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | ||
แถว 206: | แถว 206: | ||
<tr> | <tr> | ||
<td>51180503</td> | <td>51180503</td> | ||
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
− | <td> | + | <td>0</td> |
<td> | <td> | ||
* -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record | * -10 เนื่องจากแสดงข้อมูลทั้งหมด ไม่ลิมิตไว้ที่ 100 record |
รุ่นแก้ไขเมื่อ 22:21, 21 มีนาคม 2554
ประกาศให้เมื่อวันที่ 21 มกราคม 2554 ให้เลื่อนส่งจากเดิมในวันพุธที่ 9 กุมภาพันธ์ 2554 เวลา 23.59 น. ออกไปเป็น วันเสาร์ที่ 12 กุมภาพันธ์ 2554 เวลา 23.59 น.
ในการบ้านนี้นิสิตจะสร้างระบบบัญชีส่วนตัว เพื่อให้นิสิตสามารถบันทึกรายรับรายจ่ายประจำวัน รวมถึงออกรายงานสรุปรายรับรายจ่ายของตนเองได้
เนื้อหา
ข้อกำหนดเบื้องต้นเกี่ยวกับระบบบัญชีส่วนตัว
- สร้างโครงของแอพพลิเคชันขึ้นมาด้วย Rails หรือใช้แอพพลิเคชันตัวอย่างที่ใช้ Authentication ที่ดาวน์โหลดได้ที่ แอพพลิเคชันตัวอย่างที่ใช้ Authentication เพื่อนำมาปรับใช้ในการสร้างแอพพลิเคชันนี้ (นิสิตควรปรับแก้ stylesheet (CSS) ของแอพพลิเคชันให้ดูเหมาะสมกับแอพพลิเคชันของตน)
- ระบบจำเป็นต้องมีฐานข้อมูลที่ใช้ในการจัดเก็บข้อมูล โดยให้ใช้ SQLite เป็นระบบฐานข้อมูล
- ตารางในฐานข้อมูลควรถูกออกแบบตามความเหมาะสมเพื่อใช้บันทึกข้อมูลรายรับรายจ่ายประจำวันได้
- สำหรับการบ้านนี้ แอพพลิเคชันต้องมีระบบ Authentication โดยสามารถใช้ขั้นตอนวิธีตามแอพพลิเคชันตัวอย่างที่ใช้ Authentication
- สำหรับการบ้านนี้ แอพพลิเคชันไม่จำเป็นต้องมีหน้าจอเพื่อใช้ในการเพิ่มจำนวนผู้ใช้ในระบบ ผู้ใช้ทั้งหมดในระบบจะถูกสร้างเตรียมไว้ในฐานข้อมูลตั้งแต่ตอนติดตั้งแอพพลิเคชัน โดยข้อมูลผู้ใช้ในระบบทั้งหมดจะถูกเตรียมเก็บไว้ในไฟล์ db/seeds.rb เพื่อใช้ในการเตรียมข้อมูลผู้ใช้เข้าไปในฐานข้อมูลตอนติดตั้งแอพพลิเคชัน (สามารถดูตัวอย่างได้ที่ แอพพลิเคชันตัวอย่างที่ใช้ Authentication)
- กำหนดให้ผู้ใช้ 1 คนมีบัญชีรายรับรายจ่ายเพียง 1 บัญชีเท่านั้น
- ข้อมูลเริ่มต้นที่สร้างเตรียมไว้ในไฟล์ db/seeds.rb ควรมีจำนวนผู้ใช้ไม่น้อยกว่า 3 คน ส่วนข้อมูลอื่นๆ ที่จำเป็นต้องสร้างเตรียมไว้ก็ขอให้มีไม่น้อยกว่า 3 รายการในแต่ละประเภท
รายละเอียดเกี่ยวกับระบบบัญชีส่วนตัว
- หน้าหลักของแอพพลิเคชันจะเป็นหน้าล็อกอิน เพื่อเข้าใช้ระบบ
- หลังจากที่ผู้ใช้ล็อกอินผ่านเข้าระบบไปได้แล้ว หน้าของแอพพลิเคชันจะแสดงรายการรายรับและรายจ่ายของผู้ใช้ที่ได้ล็อกอินเข้าไป โดยให้ลำดับของรายการที่เข้ามาใหม่อยู่เหนือรายการที่ถูกบันทึกมาก่อน
- หน้าเพจต่างๆ ในแอพพลิเคชันควรมีเมนูที่ลิงค์ไปยังหน้าเพจอื่นที่สัมพันธ์กันอย่างเหมาะสม
- ประเภทของรายการที่ปรากฏในระบบบัญชีนี้มี 2 ชนิดคือ
- รายการรายรับ เป็นรายการที่ทำให้ยอดเงินในบัญชีมีค่าสูงขึ้น อาทิเช่น เงินเปิดบัญชี ค่าเบี้ยเลี้ยง ค่าตอบแทนผู้ช่วยสอน เงินแต๊ะเอีย เป็นต้น
- รายการรายจ่าย เป็นรายการที่ทำให้ยอดเงินในบัญชีมีค่าลดลง อาทิเช่น ค่าอาหาร ค่าเดินทาง ค่าหนังสือ ค่าตั๋วหนัง เป็นต้น
- ผู้ใช้ไม่ควรต้องกรอกข้อมูลจำนวนเงินสำหรับรายการรายจ่ายเป็นค่าติดลบ แอพพลิเคชันควรให้ผู้ใช้กรอกค่าใช้จ่ายตามจริง อาทิเช่น ค่าหนังสือ ควรกรอกเป็นจำนวนเงิน 1,200 บาท แทนที่จะต้องให้ผู้ใช้กรอกเป็นจำนวนเงิน -1,200 บาท เป็นต้น
- ประเภทของรายการในแอพพลิเคชันต้องถูกเก็บอยู่ในตาราง ซึ่งแยกออกมาจากตารางที่ใช้เก็บรายละเอียดของรายการรายรับและรายจ่าย และข้อมูลในตารางประเภทรายการจะถูกสร้างเตรียมไว้ล่วงหน้าโดยถูกเก็บไว้ใน db/seeds.rb โดยที่ข้อมูลส่วนนี้จะไม่ถูกเปลี่ยนแปลงหรือลบออกจากฐานข้อมูลในช่วงการทำงานของแอพพลิเคชันนี้
- ส่วนรายการรายรับและรายจ่ายสามารถถูกเพิ่ม ลบ และแก้ไข ในตารางรายการ ผ่านหน้าเพจของแอพพลิเคชัน โดยประเภทของรายการจะถูกอ่านเพื่อนำมาแสดงจากตารางประเภทรายการ
- รายการรายรับรายจ่ายควรมีรายละเอียดที่จำเป็น โดยที่อย่างน้อยควรประกอบด้วย วันและเวลาที่ทำรายการ ประเภทของรายการ รายละเอียดของรายการหากผู้ใช้ต้องการบันทึกเพิ่มเติมไว้ และจำนวนเงิน เป็นต้น
- แอพพลิเคชันมีหน้าเพจแสดงรายงานรายรับรายจ่ายประจำวัน
- ผู้ใช้จะป้อนวันที่เริ่มต้นและวันที่สิ้นสุดในการแสดงรายงานประจำวันนี้
- รายงานนี้จะแสดงรายการที่เกิดขึ้นของแต่ละวันในช่วงเวลาที่ผู้ใช้กำหนด โดยให้เรียงลำดับจากรายการที่เกิดขึ้นก่อนเหนือรายการที่เกิดตามมา
- เมื่อสิ้นสุดของแต่ละวัน รายงานต้องแสดงยอดเงินสุทธิของรายการที่เกิดขึ้นในวันนั้น
- เมื่อสิ้นสุดรายงาน รายงานต้องแสดงยอดเงินสุทธิของรายการที่เกิดขึ้นในช่วงวันที่ผู้ใช้ได้กำหนดมา
หลังจากทำการพัฒนาเสร็จแล้ว ให้ rollback migration ทั้งหมด (ให้ database ว่าง) แล้ว zip ไดเรคทอรีที่ rails สร้างทั้งหมดส่งมาที่อีเมล์ของ อ.ประมุข (pramook at gmail dot com) และ อ.ชาคริต (chakrit dot w at gmail dot com)
คะแนนการบ้าน 2
รหัสนิสิต | A (20) | B (20) | C (15) | D (30) | E (15) | รวม | หมายเหตุ |
50040229 | 20 | 0 | 0 | 0 | 0 | 0 |
|
50042993 | 0 | 0 | 0 | 0 | 0 | 0 |
|
50043058 | 0 | 0 | 0 | 0 | 0 | 0 |
|
50043082 | 0 | 0 | 0 | 0 | 0 | 0 | |
50043140 | 0 | 0 | 0 | 0 | 0 | 0 |
|
50043173 | 0 | 0 | 0 | 0 | 0 | 0 |
|
50043215 | 0 | 0 | 0 | 0 | 0 | 0 |
|
50043231 | 0 | 0 | 0 | 0 | 0 | 0 |
|
50043306 | 0 | 0 | 0 | 0 | 0 | 0 |
|
51043214 | |||||||
50180249 | |||||||
51180198 | 0 | 0 | 0 | 0 | 0 | 0 |
|
51180503 | 0 | 0 | 0 | 0 | 0 | 0 |
|
เกณฑ์การให้คะแนน
- A: เตรียมข้อมูลเบื้องต้น migration และ seed (20)
- B: Authentication แต่ละผู้ใช้ (20)
- C: CSS และ form layout ที่เหมาะสม (15)
- D: ความถูกต้องในการทำงานของโปรแกรม (30)
- F: รายงานรายรับรายจ่าย (15)