ข้ามไปที่เนื้อหาหลัก

การเขียนโปรแกรมแสดงความคิดเห็น (PHP Real time Comment)


หลักการทำงานตามภาพคือ การลดจำนวนครั้งในการเรียกข้อมูลจากฐานข้อมูล เพราะการดึงข้อมูลมาแสดงผลทุก 3 วินาที ถ้ามีคนใช้พร้อมกันจะทำให้เครื่องเซิร์ฟเวอร์ทำงานหนักเกินไป


ตัวอย่างคือ ในหัวข้อหนึ่ง ได้มีคนเข้ามาคอมเมนต์ไป 3 ครั้ง หากเราเข้ามาอ่านก็จะเห็นข้อความอยู่ 3 ข้อความ แต่ในขณะที่อ่านหัวข้อนั้นอยู่ คนที่ 4 อาจจะคอมเมนต์เพิ่มมาแล้วก็ได้ เพื่อให้เราเห็นคอมเมนต์ที่ 4 ในช่วงเวลาที่ใกล้กัน จึงต้องเขียนโปรแกรมให้วนรอบกลับไปทำงานทุก 3 วินาที



ซึ่งงานนี้จะใช้เทคนิค Ajax ร่วมกับ PHP เพื่อดึงข้อมูลจากฐานข้อมูล MySQL ออกมาแสดง


ถ้าดูจากโฟล์วด้านขวา จะเห็นว่าทุกครั้งที่มีการคอมเมนต์ จะมีการสร้างไฟล์ขึ้นมา 1 ไฟล์เพื่อเก็บไอดีล่าสุดของการคอมเมนต์ในหัวข้อนั้นๆ ก่อนที่เราจะไปดึงฐานข้อมูลโดยตรง เราก็เขียนโปรแกรมเช็กก่อนว่า ไอดีล่าสุดที่แสดงอยู่ ณ ขณะนั้น น้อยกว่าไอดี ที่เก็บไว้ในไฟล์นี้หรือไม่

ถ้าน้อยกว่าล่ะก็ แสดงว่ามีคนมาคอมเมนต์เพิ่มเติมแล้ว

นอกจากวิธีเช็กก่อนคิวรี่ฐานข้อมูลแล้ว อีกวิธีหนึ่งที่จะช่วยลดการทำงานของ MySQL และเพิ่มความเร็วให้กับการแสดงผลได้ดียิ่งขึ้น ก็คือ การสร้างเท็กไฟล์ ของคอมเมนต์ชุดนั้นเก็บไว้เลย เมื่อเปิดมาอ่านกระทู้หัวข้อไหน ก็ดึงไฟล์มาแสดงได้ทันที 


หมายเหตุ
หากใครสนใจเรื่อง Chat Room ที่คล้ายกับเฟซบุ๊ก แนะนำให้ศึกษา http://nodejs.org/
ศึกษาข้อมูลเพิ่มเติมโดยค้นหาจาก Google.co.th โดยค้นหาด้วยคีย์เวิร์ด "  node.js คืออะไร"


--------------------------------------------
ติดตามเรื่องราวการเขียนโปรแกรม PHP ได้ที่
https://www.youtube.com/user/PHPcodingAndDesign/channels

เตรียมตัวก่อนเขียน PHP 5.5
https://www.youtube.com/playlist?list=PLEFxdFJkMLu78rEFPPzkpeieOGEJp730g

ความคิดเห็น

  1. แล้วถ้าไม่ คิวรี่ดึง id คอมเม้นสุดท้ายมาเช็คในไฟล์ id ล่าสุดที่เราบันทึกใว้ จะรู้ได้ไงว่า id สุดท้ายคืออะไร หรือว่า คิวรี่ id ทุก 3 วินาทีแบบนี้ก็เท่ากับว่า ดึงข้อมูลทุก 3 วินาทีตลอดเลยไช่มั้ยคับ

    ตอบลบ

แสดงความคิดเห็น

โพสต์ยอดนิยมจากบล็อกนี้

การแชร์สแกนเนอร์ ถึงทำไม่ได้แต่ก็มีวิธีช่วยประหยัดขั้นตอนการทำงาน

"พี่ครับขอใช้เครื่องพี่สแกนเอกสารหน่อยครับ" "พี่ครับขอสแกนอีกสักสองแผ่นครับ" "พี่ครับพอดีมีเอกสารต้องสแกนเพิ่มน่ะครับ" ทุกครั้งที่ต้องสแกนเอกสารเป็นไฟล์เก็บไว้ในคอมพิวเตอร์ ผมจะต้องลุกไปขอใช้เครื่องพิมพ์แบบ All-In-One ของพี่โจ้ทุกครั้ง บางครั้งก็เกรงใจแกครับ เห็นกำลังใจจดใจจ่ออยู่กับงานตรงหน้า ไหนจะต้องตอบคำถามคำโน้นคนนี้ทาง MSN บ้าง Facebook บ้าง ^___^ พอไปขอใช้เครื่องทีไรก็ดูแกจะไม่สบอารมณ์เท่าไหร่ พยายามค้นหาวิธีแชร์สแกนเนอร์จากในอินเตอร์เน็ตอยู่หลายวัน ก็ไม่เจอวิธีที่จะสามารถแชร์สแกนเนอร์ให้เครื่องอื่นได้ใช้งานได้เลย แชร์ได้แค่ให้สั่งพิมพ์จากเครื่องอื่นๆได้เท่านั้น สุดท้ายก็เลยตัดสินใจใช้เทคนิคเล็กๆ น้อยๆ ที่ได้พบเจอมาใช้ประหยัดเวลา และไม่รบกวนการทำงานและสนทนาของพี่โจ้ ได้วิธีนึง นั่นก็คือ ตั้งค่าสแกนเนอร์ให้บันทึกอัตโนมัติ ไว้ในโฟลเดอร์ที่กำหนด แล้วก็ทำการแชร์โฟลเดอร์เครื่องพี่โจ้ทิ้งไว้ซะเลย 1. ตั้งค่าให้สแกนอัตโนมัติเมื่อกดปุ่มสแกน 2. กำหนดให้บันทึกลงโฟลเดอร์ที่แชร์ไว้แล้ว (แชร์โฟลเดอร์เก็บเอกสารสแกนของคอมฯเครื่องนั้นไว้) 3. ...

เมื่อโปรแกรมเมอร์ไม่ชอบเขียนโค้ดอีกต่อไป

ในวันที่จิตใจเราเลือกหนทางใหม่ ในวันที่ทุกอย่างยังสับสนวุ่นวายเต็มหัว แต่สิ่งน่ากลัวไม่ใช่ "ทางเลือก" แต่มันคือ "ทางรอด" บางทีมันก็ยากนะ ที่จะตัดสินใจว่าสิ่งที่เลือกดีที่สุดสำหรับเราแล้วหรือไม่!! เพราะอนาคตเป็นสิ่งที่คาดเดาได้ยากเหลือเกิน แม้มันจะมีรูปแบบที่ไม่แตกต่างกันนัก และพอจะคาดเดากรรมที่ตามมาก็ตามที และเมื่อวันนั้น วันที่จะต้องตัดสินใจ มาเร็วกว่าที่คิด เราอาจจะไม่ทันตั้งตัวเลยสักนิด ความคิดที่เคยเชื่อมั่นอาจจะสั่นคลอนลงอย่างง่ายดาย ความฝันที่ไม่เคยเริ่ม มันก็เป็นได้แค่ "ความเพ้อฝัน"

FPDF ภาษาไทย กับ วรรณยุกต์ลอย

สำหรับงานเขียนโปรแกรมเว็บแอพฯ ด้วย PHP ที่ต้องทำการส่งออกข้อมูลเป็นไฟล์เอกสาร PDF นั้น เมื่อลองค้นดูแล้วก็เจอกับ FPDF เป็นคลาสที่เขียนขึ้นมาสำหรับงานนี้โดยเฉพาะ แต่กับภาษาไทยแล้วก็ต้องเจอกับปัญหาสุดคลาสสิคคือ รองรับภาษาไทยไม่ร้อยเปอร์เซ็นต์ ^^" บทความที่สอนการใช้งานเบื้องต้นที่ครอบคลุมการทำงานของ FPDF http://www.select2web.com/category/fpdf จะมีบทความแนะนำการใช้ฟอนต์ภาษไทยอยู่ที่ลิงค์นี้ http://www.select2web.com/fpdf/fpdf-lesson-10.html ดาวน์โหลดและสร้างฟอนต์มาใช้เอง http://witkub.blogspot.com/2011/11/fpdf.html สำหรับวิธีแก้ไขปัญหาวรรณยุกต์ลอย ลองดูวิธีจากที่นี่ http://punnawatt.blogspot.com/2009/07/pdf.html สุดท้ายแล้วลองทดลองมาหมด ก็ยังไม่ได้คำตอบที่ตรงใจครับ เพราะไม่สามารถแก้สระลอยได้อย่างแท้จริง เพราะเงื่อนไขข้อมูลจริงไม่อาจจะทำให้เหมือนในตัวอย่างได้ ก็เลยถอดใจเรื่องวรรณยุกต์ลอย นอกจากปัญหาเรื่องวรรณยุกต์ลอย แล้วฟอนต์บางตัวก็เกิดปัญหาวรรณยุกต์ซ้อนทับกันด้วย เช่นคำว่า "นี้" เมื่อผลลัพธ์ออกมา สระอี และวรรณยุกต์โท จะทับกัน สรุป 1. ดาวน์โหล...

PHP CI MANIA