 |
ถามเกี่ยวกับ 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 |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
|
|