Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,037

HOME > PHP > PHP Forum > ถามเกี่ยวกับ webboard หน่อยครับ อยากรู้วิธีทำ นับจำนวน คนตอบ กับ คนตั้งกระทู้ แล้วก็ กระทู้ที่ตั้งครั้งล่าสุด หรือ ตอบล่าสุดน่ะครับ



 

ถามเกี่ยวกับ webboard หน่อยครับ อยากรู้วิธีทำ นับจำนวน คนตอบ กับ คนตั้งกระทู้ แล้วก็ กระทู้ที่ตั้งครั้งล่าสุด หรือ ตอบล่าสุดน่ะครับ

 



Topic : 091047



โพสกระทู้ ( 105 )
บทความ ( 0 )



สถานะออฟไลน์




Count post

อยากทราบว่า จะทำตัว Last post กับ นับ กระทู้ / คนที่ตอบยังไงครับ

ผมเข้าใจว่า ถ้า ทำแยก database ของแต่ละ หัวข้อ มันจะดีกว่าไหมครับ

หรือว่า ควรรวม database ตัวเดียว? มันควรจะนับ จำนวนกระทู้ กับ จำนวน คนตอบ ยังไงหรอครับ

แล้วก็ last post นี่ทำยังไงหรอครับ



Tag : PHP, Ms SQL Server 2008







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2013-02-18 10:42:57 By : copsychus View : 865 Reply : 11
 

 

No. 1



โพสกระทู้ ( 130 )
บทความ ( 0 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์


ทีผมเคยทำ มี 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
 


 

No. 2



โพสกระทู้ ( 4,169 )
บทความ ( 7 )

Hall of Fame 2012

สถานะออฟไลน์


ตัวอย่าง
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
 

 

No. 3



โพสกระทู้ ( 105 )
บทความ ( 0 )



สถานะออฟไลน์


เอิ่มแล้ว ถ้าสมมุติว่า หัวข้อผมเป็นแบบนี้

หัวข้อ 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
 


 

No. 4



โพสกระทู้ ( 130 )
บทความ ( 0 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์


ตอบความคิดเห็นที่ : 3 เขียนโดย : copsychus เมื่อวันที่ 2013-02-18 11:30:58
รายละเอียดของการตอบ ::
เอิ่มแล้ว ถ้าสมมุติว่า หัวข้อผมเป็นแบบนี้

หัวข้อ A-J

หัวข้อ K-P

หัวข้อ T-Z --> เวลากดแล้ว จะเข้าไปอีกหน้า ที่มี กระทู้เยอะๆเลย อันนี้จะเป็น หัวข้อที่ ส่งถึง เจ้าของที่มีชื่อนำหน้าด้วยตั้งแต่ T - Z

ถ้าทำแบบนี้ ผมต้องแยก database ของแต่ละหัวข้อไหมครับ [ตาราง aQuestion, aReply kQuestion, kReply tQuestion,tReply] เพื่อเก็บคำถาม และ คำตอบของแต่ละ topic, และยังทำให้ใช้ในการนับ จำนวนคนตอบ และ ผู้ตั้งได้อีกด้วย

หรือว่า รวมกันได้ ถ้ารวมกันได้ มีวิธีทำยังไงหรอครับ อันนี้คิดไม่ออกเลย


ไม่ต้องแยกก็ได้ ก็เพิ่มตารางมาอีกตาราง เก็บ หัวข้อก็ได้ครับ
เช่น Question_type มี id ชื่อหัวข้ออะไรก็ใส่ไป

ที่ตาราง Question ก็เก็บ id ของ Question_type แค่นี้ก็ได้แล้วครับ
ตารางเก็บข้อมูล จะได้ไม่ซ้ำซ้อนกันมาก เวลาทำ report ก็จะได้ง่ายขึ้นด้วยครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-02-18 11:38:14 By : nutsuanplu
 


 

No. 5



โพสกระทู้ ( 105 )
บทความ ( 0 )



สถานะออฟไลน์


เอิ่มถ้าไม่แยกแล้วจะนับ คำตอบยังไงอะครับ . . . ในเมื่อคำตอบ ของคนที่มาตอบ มีตั้งหลายชื่อ มันจะนับยังไงให้เข้ากลุ่ม 3 กลุ่มแบบด้านบนเหรอครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-02-18 11:50:10 By : copsychus
 


 

No. 6

Guest


ตอบความคิดเห็นที่ : 2 เขียนโดย : Ex-[S]i[L]e[N]t เมื่อวันที่ 2013-02-18 11:22:21
รายละเอียดของการตอบ ::
แนะนำของคุณ Ex-[S]i[L]e[N]t เข้าใจง่าย

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-02-18 12:07:04 By : Guest
 


 

No. 7



โพสกระทู้ ( 105 )
บทความ ( 0 )



สถานะออฟไลน์


ของคุณ Ex-[S]i[L]e[N]t เข้าใจแล้วครับผม แต่ มันก็ยังแก้ปัญหาที่คิดไม่ตก ของ #5 ไม่ได้อยู่ดีครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-02-18 12:09:08 By : copsychus
 


 

No. 8



โพสกระทู้ ( 130 )
บทความ ( 0 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์


สมมุติ นะครับ ที่ตาราง 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
 


 

No. 9



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

ลองดูครับ เคยเขียนไว้ครับ

PHP สร้าง WebBoard กระดานถาม-ตอบ เว็บบอร์ดสำหรับเว็บ PHP กับ MySQL

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-02-18 12:19:11 By : mr.win
 


 

No. 10



โพสกระทู้ ( 4,169 )
บทความ ( 7 )

Hall of Fame 2012

สถานะออฟไลน์


แล้วทำไม เราไม่เพิ่ม 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
 


 

No. 11



โพสกระทู้ ( 105 )
บทความ ( 0 )



สถานะออฟไลน์


ขอบคุณครับผม ขอลองก่อนครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-02-18 13:01:38 By : copsychus
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ถามเกี่ยวกับ webboard หน่อยครับ อยากรู้วิธีทำ นับจำนวน คนตอบ กับ คนตั้งกระทู้ แล้วก็ กระทู้ที่ตั้งครั้งล่าสุด หรือ ตอบล่าสุดน่ะครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 04
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่