ถามเกี่ยวกับ webboard หน่อยครับ อยากรู้วิธีทำ นับจำนวน คนตอบ กับ คนตั้งกระทู้ แล้วก็ กระทู้ที่ตั้งครั้งล่าสุด หรือ ตอบล่าสุดน่ะครับ
ทีผมเคยทำ มี 3 ตารางครับ
- topic เอาไว้เก็บหัวข้อ เก็บ การนับผู้ตอบ นับการอ่าน ผมเก็บไว้ตารางนี้
- post เอาไว้เก็บผู้ตอบกระทู้
- type เอาไว้เก็บข้อมูลว่า เป็นหัวข้อแบบใด เช่น หัวข้อทั่วไป หัวข้อร้องเรียน
หลักๆ ก็เวลาคลิ๊กอ่าน จะให้ update ตาราง topic ที่ฟิลด์ count_read
ผู้ตอบก็ count * post where topic = 'xxx'
ประมาณนี้ครับ
ประวัติการแก้ไข 2013-02-18 11:22:31
Date :
2013-02-18 11:16:45
By :
nutsuanplu
ตัวอย่าง
tb_question
: quesID,question,datetime,count
tb_ans
:ansID,quesID,ans,datetime
นับจำนวนกระทู้
Code (PHP)
<?
$select=mysql_query("SELECT count(*) as total FROM tb_question");
$result=mysql_fetch_array($select);
echo $result['total'];
?>
นับจำนวนคำตอบ
Code (PHP)
<?
$quesID="5";
$select=mysql_query("SELECT count(*) as total FROM tb_ans WHERE quesID='".$quesID."'");
$result=mysql_fetch_array($select);
echo $result['total'];
?>
ประวัติการแก้ไข 2013-02-18 11:22:55
Date :
2013-02-18 11:22:21
By :
Ex-[S]i[L]e[N]t
เอิ่มแล้ว ถ้าสมมุติว่า หัวข้อผมเป็นแบบนี้
หัวข้อ A-J
หัวข้อ K-P
หัวข้อ T-Z --> เวลากดแล้ว จะเข้าไปอีกหน้า ที่มี กระทู้เยอะๆเลย อันนี้จะเป็น หัวข้อที่ ส่งถึง เจ้าของที่มีชื่อนำหน้าด้วยตั้งแต่ T - Z
ถ้าทำแบบนี้ ผมต้องแยก database ของแต่ละหัวข้อไหมครับ [ตาราง aQuestion, aReply kQuestion, kReply tQuestion,tReply] เพื่อเก็บคำถาม และ คำตอบของแต่ละ topic, และยังทำให้ใช้ในการนับ จำนวนคนตอบ และ ผู้ตั้งได้อีกด้วย
หรือว่า รวมกันได้ ถ้ารวมกันได้ มีวิธีทำยังไงหรอครับ อันนี้คิดไม่ออกเลย
Date :
2013-02-18 11:30:58
By :
copsychus
เอิ่มถ้าไม่แยกแล้วจะนับ คำตอบยังไงอะครับ . . . ในเมื่อคำตอบ ของคนที่มาตอบ มีตั้งหลายชื่อ มันจะนับยังไงให้เข้ากลุ่ม 3 กลุ่มแบบด้านบนเหรอครับ
Date :
2013-02-18 11:50:10
By :
copsychus
ของคุณ Ex-[S]i[L]e[N]t เข้าใจแล้วครับผม แต่ มันก็ยังแก้ปัญหาที่คิดไม่ตก ของ #5 ไม่ได้อยู่ดีครับ
Date :
2013-02-18 12:09:08
By :
copsychus
สมมุติ นะครับ ที่ตาราง Question_type
id 1 name คือ A-J
id 2 name คือ K-P
id 3 name คือ T-Z
ที่ตาราง Question ก็เก็บ id ของตาราง Question_type ไว้ด้วย
ส่วนตาราง Reply อาจเก็บ id ของตาราง Question (ผมไม่รู้ว่าคุณ Boss ออกแบบตารางอย่างไร)
เวลานับก็ count(*) โดย join ตาราง Question กับ Replay แล้วก็ใส่เงื่อนไข where Question_type_id = '3' ประมาณนี้
ก็จะได้การนับจำนวน Question_type_id = '3' ซึ่งก็คือ T-Z ครับ
Date :
2013-02-18 12:14:07
By :
nutsuanplu
ลองดูครับ เคยเขียนไว้ครับ
PHP สร้าง WebBoard กระดานถาม-ตอบ เว็บบอร์ดสำหรับเว็บ PHP กับ MySQL
Date :
2013-02-18 12:19:11
By :
mr.win
แล้วทำไม เราไม่เพิ่ม tb_ans : name หรือ memberID หละครับ แล้วค่อยนับค่าจาก
Code (PHP)
$quesID="5";
$Member="Saranyu";
$select=mysql_query("SELECT count(*) as total FROM tb_ans WHERE quesID='".$quesID."' AND Member ='".$Member."'");
$result=mysql_fetch_array($select);
echo $result['total'];
Date :
2013-02-18 12:29:17
By :
Ex-[S]i[L]e[N]t
ขอบคุณครับผม ขอลองก่อนครับ
Date :
2013-02-18 13:01:38
By :
copsychus
Load balance : Server 04