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,027

HOME > PHP > PHP Forum > รบกวนทุกท่านอีกครั้งแล้วครับ ขอไอเดีย หรือหลักการแสดงข้อมูลหน่อยครับ



 

รบกวนทุกท่านอีกครั้งแล้วครับ ขอไอเดีย หรือหลักการแสดงข้อมูลหน่อยครับ

 



Topic : 047448

Guest




คือผมสร้างระบบเก็บสถิตครับแล้วมีปัญหา ออกรายงาน ประมาณว่า

-สร้างฐานข้อมูล 3 ตาราง

CREATE TABLE `loglibrary` เก็บ log

`id` int(13)
`userid`
`timestart`
`daystart`

CREATE TABLE `user` เก็บขัอมูลสมายชิก
`id` int(13)
`userid`
`username`
`sex`
`type`
`status`
`day`


CREATE TABLE `typeuser` เก็บประเภทสมาชิก
`id` int(13) ,
`typename`
`data`
`day`



ข้อมูลสถิติรายวันของเดือนสิงหาคม ปี 2010

typeuser1 typeuser2 typeuser3
1 สิงหาคม 2010 18 492 106
2 สิงหาคม 2010 0 0 0
3 สิงหาคม 2010 0 0 0
4 สิงหาคม 2010 25 372 91
... ... ... ...
30 สิงหาคม 2010 25 623 110
31 สิงหาคม 2010 0 0 0



... ผมเขียนโค๊ดแสงผลได้แล้วครับ แต่หากมีข้อมูลเยอะๆ จะ ค้างครับ

ผมก็บโค๊ดมาลงไม่เป็น ใช้หลักการประณนี้ครับ
- เช็ควันเดือนปี ในฐานข้อมูล loglibrary เก็บอาเรย์ userid ไว้
- ดึงข้อมูลจากตาราง typeuser ว่ามีประเภทสมาชิกหรือไม่
- เช็ค อาเรย์ userid และ typeuser ในตาราง user ว่ามีหรือไม่
- ตั้งตัวแปรเก็บผลรวมแต่ละวัน แยกตามประเภท แล้วแสดงผลครับ

* ที่ผมทำถูกหรือเปล่าครับ ทำไมมันช้าจัง มีวีธีการดีๆ กว่านี้ใหมครับ ขอคำแนะนำด้วยครับ



Tag : PHP, MySQL, HTML/CSS, JavaScript, CakePHP, Win (Windows App)







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2010-08-21 16:13:33 By : libservice View : 743 Reply : 3
 

 

No. 1

Guest


file

Code (PHP)
                                 <?
								 $d='1';
							 $m=$_REQUEST['Rmonth'];
							  $y=$_REQUEST['Ryear'];
							//  $m=8; $y=2010 ;
							$num_days =cal_days_in_month(CAL_GREGORIAN,$m,$y);
							while($d<=$num_days){
								$alleid='';
								$d=str_pad($d,2,"0",str_pad_left) ;
								 $report1="$d/$m/$y";
								$sql="select * from loglibrary where daystart='$report1' ";
								$result=mysql_query($sql) ;
								$numrow=mysql_num_rows($result);
								for ($log=0; $log<$numrow ; $log++){
								$fetche=mysql_fetch_array($result);
								$dbuserid1=$fetche['userid'];
								$dbday=$fetche['daystart'] ;									
								$alleid[]=$dbuserid1;
					
									//	echo "$dbday - $dbuserid1<br>" ;
					}
					?>
                                 <td align="center" valign="middle"><?
											echo   displaydate($report1)."<br>";				
						  ?></td> 
                                 <?
						$sqlh= "select  *  from  typeuser order by id"; 
					$resulth=mysql_query($sqlh);
					$numrowsh=mysql_num_rows($resulth);
 					while($fetchh=mysql_fetch_array($resulth)){
					 $typeid1=$fetchh['id'];
					$typename1=$fetchh['typename'];
											
											for ($i=0; $i<$log; $i++) {						   
 										
													 $sqleidt="select  *  from user WHERE userid=$alleid[$i]  AND type=$typeid1";
													$resulteidt=mysql_query($sqleidt) ;
													$numroweidt=mysql_num_rows($resulteidt);	
												//	for ($eidt=0; $eidt<$numroweidt ; $eidt++){
												
													while($fetcheid=mysql_fetch_array($resulteidt)){
																		
																		//$fetcheid=mysql_fetch_array($resulteidt);
																		$dbid=$fetcheid['id'];
																		$dbuser=$fetcheid['userid'];
																		$dbtype=$fetcheid['type'];
																		$db2sex=$fetcheid['sex']; 
															// echo $dbuser."---".$report1."<br>" ;	
															if (!empty($dbuser)){	 $typesa++ ; }	else{  $typesa=0;}	
																//	if ($dbuser!=''){ $typesa++ ;  }
													}
											}    	                    
										if( $typesa==0) { $typesa='-' ;}
										 ?>
																				
                                 <td align="center" valign="middle"><? echo   $typesa."<br>" ;  	$typesa=0; ?> </td>
                               <? }
								?></tr>  
							   <? 
						 $d++ ;} ?>








แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2010-08-21 16:33:25 By : libservice
 


 

No. 2



โพสกระทู้ ( 11,835 )
บทความ ( 10 )

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

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


line 192 มันอยู่ตรงไหนละครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2010-08-21 17:18:15 By : PlaKriM
 

 

No. 3



โพสกระทู้ ( 1,127 )
บทความ ( 2 )



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


จากโค๊ดผมว่า ลองศึกษา เรื่อง การ JOIN TABLE

https://www.thaicreate.com/tutorial/sql-join.html

ครับผม แล้ว การคิวรี่ จะดูง่ายขึ้น
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2010-08-22 11:06:10 By : iieszz
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : รบกวนทุกท่านอีกครั้งแล้วครับ ขอไอเดีย หรือหลักการแสดงข้อมูลหน่อยครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 01
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 อัตราราคา คลิกที่นี่