|  | 
	                
  
    | 
	 
        เรื่องกราฟ Jpgrah จากฐานข้อมูล งงกลับการ query มาก ช่วยดูให้หน่อยครับ     |  
    |  |  
 
	
		|  |  |  |  |  
		|  |  | 
          
            | ot1,ot2,ot3,...,ot7 คือ ot_id ในตารางฐานข้อมูล กราฟจะแสดง ot1 มีผู้ป่วยกี่คน ot2 กี่คน .... ประมาณนี้แหละครับ 
 ตัวอย่างโค้ด
 
 <?php
		include("config.php");
		include (".../jpgraph/jpgraph.php");
		include (".../jpgraph/jpgraph_bar.php");
		
		// ติดต่อ ฐานข้อมูล เลือกข้อมูลขึ้นมาเพื่อแสดงกราฟ
		$strSQL = "SELECT ot_id FROM therapy";
		$objQuery = mysql_query($strSQL) or die ("Error Query [".$strSQL."]");
		// เตรียมข้อมุลที่จะแสดง เพื่อสร้างกราฟ
		$datay=array();
		while($objResult = mysql_fetch_array($objQuery))
		{
		$datay[] = $objResult["ot_id"];
		}
		
		//$datay = array();
		// Create the graph. 
		$graph = new Graph(600,400);    
		$graph->SetScale("textlin");
		$graph->SetMarginColor('navy:1.9');
		$graph->SetBox();
		// Create and add a new text
		$txt=new Text('ทดสอบ');
		$txt->SetPos(10,20);
		$txt->SetColor('darkred');
		$txt->SetFont(FF_ANGSA,FS_BOLD,15);
		$txt->SetBox('yellow','navy','[email protected]');
		$graph->AddText($txt);
		// Setup the titles
		$graph->title->Set('ทดสอบ');
		$graph->xaxis->title->Set('แกน-X');
		$graph->yaxis->title->Set('แกน-Y');
		$graph->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->yaxis->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->xaxis->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->title->Set('ทดสอบ');
		$graph->title->SetFont(FF_ANGSA,FS_BOLD,20);
		$graph->SetTitleBackground('lightblue:1.3',TITLEBKG_STYLE2,TITLEBKG_FRAME_BEVEL);
		$graph->SetTitleBackgroundFillStyle(TITLEBKG_FILLSTYLE_HSTRIPED,'lightblue','blue');
		// Create a bar pot
		$bplot = new BarPlot($datay);
		$bplot->SetFillColor('darkorange');
		$bplot->SetWidth(0.6);
		$bplot->SetPattern(PATTERN_CROSS1,'navy');
		$graph->Add($bplot);
		$graph->Stroke();
?>
 ฐานข้อมูล
 
  
  
 รูปแบบกราฟที่ต้องการ
 
 
  
  
 ช่วย query ให้ดูเป็นตัวอย่างสักกราฟเถอะครับ
 
 
 
 Tag : PHP, MySQL
 
 
 |  
            | 
 ประวัติการแก้ไข
 2012-05-28 06:49:17
 |  
            | 
              
                |  |  |  |  
                |  | 
                    
                      | Date :
                          2012-05-28 06:31:45 | By :
                          บู้ | View :
                          1877 | Reply :
                          8 |  |  |  
                |  |  |  |  |  
            |  |  
		            |  |  
		|  |  |  |  |  
  
    | 
 
        
          |  |  |  |  |  
          |  |  | 
            
              | โค้ดฐานข้อมูล 
 Code
 
 CREATE TABLE `therapy` (`the_id` int(10) NOT NULL,
 `pat_hn` int(10) NOT NULL,
 `ot_id` tinyint(2) NOT NULL,
 `the_treat` text collate utf8_unicode_ci NOT NULL,
 `the_date` date NOT NULL,
 PRIMARY KEY  (`the_id`)
 ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
 
 --
 -- dump ตาราง `therapy`
 --
 
 INSERT INTO `therapy` VALUES (1, 6666666, 5, 'ปั่นจักรยาน', '2012-03-05');
 INSERT INTO `therapy` VALUES (2, 5018107, 5, '', '2011-05-12');
 INSERT INTO `therapy` VALUES (8, 4631987, 5, 'ยกถุงทราย', '2012-04-08');
 INSERT INTO `therapy` VALUES (9, 4706928, 5, 'ใส่ห่วง', '2007-08-16');
 INSERT INTO `therapy` VALUES (11, 4616632, 5, 'โยนลูกบอล', '2012-04-10');
 INSERT INTO `therapy` VALUES (13, 4616632, 3, 'หนึบไม้หนีบผ้า', '2012-04-17');
 INSERT INTO `therapy` VALUES (14, 4616632, 3, 'หนึบไม้หนีบผ้า', '2012-04-17');
 INSERT INTO `therapy` VALUES (16, 4630800, 3, 'เดินออกกำลังกาย', '2012-04-19');
 INSERT INTO `therapy` VALUES (17, 4632597, 3, 'ตักทราย', '2012-04-21');
 INSERT INTO `therapy` VALUES (18, 4730573, 4, 'ดึงเชือก', '2012-04-22');
 INSERT INTO `therapy` VALUES (19, 4835394, 5, 'หยิบลูกบอลใส่ตระกร้า', '2012-04-17');
 INSERT INTO `therapy` VALUES (20, 5111647, 4, 'ยกถุงทราย', '2012-04-23');
 INSERT INTO `therapy` VALUES (21, 5107188, 5, 'คีบลูกปิงปอง', '2012-04-23');
 INSERT INTO `therapy` VALUES (22, 5318668, 4, 'ฝึกมือ', '2012-04-23');
 INSERT INTO `therapy` VALUES (23, 5316452, 3, 'ฝึกใช้ช้อนส้อม', '2012-04-23');
 INSERT INTO `therapy` VALUES (24, 5313192, 3, 'ฝึกใส่เสื้อผ้า', '2012-04-23');
 INSERT INTO `therapy` VALUES (25, 5305947, 3, 'ฝึกพูด', '2012-04-23');
 INSERT INTO `therapy` VALUES (26, 5300657, 2, 'ปั่นจักรยานมือ', '2012-04-23');
 INSERT INTO `therapy` VALUES (28, 4600225, 1, 'วันที่ 1', '2012-05-15');
 INSERT INTO `therapy` VALUES (29, 4600225, 1, 'วันที่ 2', '2012-05-16');
 INSERT INTO `therapy` VALUES (30, 4600225, 2, 'วันที่ 3', '2012-05-17');
 INSERT INTO `therapy` VALUES (31, 4600225, 2, 'วันที่ 4', '2012-05-18');
 INSERT INTO `therapy` VALUES (32, 4600225, 3, 'วันที่ 5', '2012-05-19');
 INSERT INTO `therapy` VALUES (33, 4600225, 3, 'วันที่ 6', '2012-05-20');
 INSERT INTO `therapy` VALUES (34, 4600225, 4, 'วันที่ 7', '2012-05-21');
 INSERT INTO `therapy` VALUES (36, 4606611, 5, 'วันที่ 1', '2012-05-15');
 INSERT INTO `therapy` VALUES (37, 4608995, 4, 'วันที่ 1', '2012-05-15');
 INSERT INTO `therapy` VALUES (38, 4812493, 3, 'ทดสอบ', '2012-05-23');
 INSERT INTO `therapy` VALUES (39, 4812493, 1, 'ทดสอบการวิ่ง', '2012-05-22');
 INSERT INTO `therapy` VALUES (40, 4812493, 1, '', '2012-05-21');
 INSERT INTO `therapy` VALUES (41, 4600225, 5, 'เดินบันได', '2012-05-23');
 INSERT INTO `therapy` VALUES (42, 4815289, 4, 'ปั่นจักรยาน', '2012-05-23');
 
 |  
              | 
                
                  |  |  |  |  
                  |  | 
                      
                        | Date :
                            2012-05-28 06:36:36 | By :
                            บู้ |  |  |  
                  |  |  |  |  |  |  |  
          |  |  |  |  |  
 
        
          |  |  |  |  |  
          |  |  | 
            
              | Code (PHP) 
 SELECT t.ot_id as ot_id, COUNT(t.ot_id) as count_ot_id 
FROM therapy AS t 
GROUP BY t.ot_id
 
 ลองดูตามนี้ครับ แต่ให้ระวังเรื่องชื่อฟิลดิ์ที่จะนำไปใช้ให้ถูกต้องด้วยนะครับ ถ้าต้องการเปลี่ยนชื่อฟิลดิ์ก็ได้ตามสบายครับ
 
 |  
              | 
                
                  |  |  |  |  
                  |  | 
                      
                        | Date :
                            2012-05-28 08:55:13 | By :
                            Songkram |  |  |  
                  |  |  |  |  |  |  |  
          |  |  |  |  |  
 
        
          |  |  |  |  |  
          |  |  | 
            
              | ขอบคุณครับ ได้ลองดูแล้ว แต่กราฟมันก็ยังไม่ใช่ มันออกมาเป็นอย่างนี้ มันน่าจะเป็น ot_id 1 = 4 , ot_id 2 = 3 , ot_id 3 = 10 ... ตามฐานข้อมูล 
 
  
 โค้ดที่แก้ครับ
 
 
 <?php
		include("config.php");
		include (".../jpgraph/jpgraph.php");
		include (".../jpgraph/jpgraph_bar.php");
		
		// ติดต่อ ฐานข้อมูล เลือกข้อมูลขึ้นมาเพื่อแสดงกราฟ
		$strSQL = "SELECT t.ot_id as ot_id, COUNT(t.ot_id) as count_ot_id FROM therapy AS t GROUP BY t.ot_id";
		$objQuery = mysql_query($strSQL) or die ("Error Query [".$strSQL."]");
		// เตรียมข้อมุลที่จะแสดง เพื่อสร้างกราฟ
		$datay=array();
		while($objResult = mysql_fetch_array($objQuery))
		{
		$datay[] = $objResult["ot_id"];
		}
		
		//$datay = array();
		// Create the graph. 
		$graph = new Graph(600,400);    
		$graph->SetScale("textlin");
		$graph->SetMarginColor('navy:1.9');
		$graph->SetBox();
		// Create and add a new text
		$txt=new Text('ทดสอบ');
		$txt->SetPos(10,20);
		$txt->SetColor('darkred');
		$txt->SetFont(FF_ANGSA,FS_BOLD,15);
		$txt->SetBox('yellow','navy','[email protected]');
		$graph->AddText($txt);
		// Setup the titles
		$graph->title->Set('ทดสอบ');
		$graph->xaxis->title->Set('แกน-X');
		$graph->yaxis->title->Set('แกน-Y');
		$graph->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->yaxis->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->xaxis->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->title->Set('ทดสอบ');
		$graph->title->SetFont(FF_ANGSA,FS_BOLD,20);
		$graph->SetTitleBackground('lightblue:1.3',TITLEBKG_STYLE2,TITLEBKG_FRAME_BEVEL);
		$graph->SetTitleBackgroundFillStyle(TITLEBKG_FILLSTYLE_HSTRIPED,'lightblue','blue');
		// Create a bar pot
		$bplot = new BarPlot($datay);
		$bplot->SetFillColor('darkorange');
		$bplot->SetWidth(0.6);
		$bplot->SetPattern(PATTERN_CROSS1,'navy');
		$graph->Add($bplot);
		$graph->Stroke();
?>
 |  
              | 
                
                  |  |  |  |  
                  |  | 
                      
                        | Date :
                            2012-05-28 09:49:33 | By :
                            บู้ |  |  |  
                  |  |  |  |  |  |  |  
          |  |  |  |  |  
 
        
          |  |  |  |  |  
          |  |  | 
            
              | ก็คุณใช้ "ot_id" มาเป็น Data มันก็ได้อย่างนั้นแหละครับ คุณต้องใช้ "count_ot_id" ครับ หรือจะตั้งชื่อใหม่ก็ได้ครับ  เพราะฉะนั้นให้เปลี่ยนที่บันทัดนี้ครับ 
 Code (PHP)
 
 $datay[] = $objResult["ot_id"];
 
 เปลี่ยนเป็น
 
 Code (PHP)
 
 $datay[] = $objResult["count_ot_id"];
 
 |  
              | 
                
                  |  |  |  |  
                  |  | 
                      
                        | Date :
                            2012-05-28 10:27:09 | By :
                            Songkram |  |  |  
                  |  |  |  |  |  |  |  
          |  |  |  |  |  
 
        
          |  |  |  |  |  
          |  |  | 
            
              | ขอบคุณมากครับ ขอถามต่อยอดอีกนิดนะครับ จะไป join table ยังไงครับ คือ ot_id join กับ ตาราง ot ดังนี้นะครับ ot_id 1 = ot_code 1 , ot_id 2 = ot_code 2 , ot_id 3 = ot_code 3 , แต่ ot_id 4 = ot_code 6 , ot_id 5 = ot_code 7 คืออยากให้กราฟออกมาเหมือน คห. 1 นะครับ 
 ตาราง ot ครับ
 
 CREATE TABLE `ot` (
 `ot_id` int(2) NOT NULL,
 `ot_code` varchar(20) collate utf8_unicode_ci NOT NULL,
 `tit_id` int(2) NOT NULL,
 `ot_name` varchar(50) collate utf8_unicode_ci NOT NULL,
 `ot_user` varchar(20) collate utf8_unicode_ci NOT NULL,
 `ot_pass` varchar(20) collate utf8_unicode_ci NOT NULL,
 PRIMARY KEY  (`ot_id`)
 ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
 
 --
 -- dump ตาราง `ot`
 --
 
 INSERT INTO `ot` VALUES (1, '1', 5, 'สมหมาย', 'ot1', 'ot1');
 INSERT INTO `ot` VALUES (2, '2', 5, 'สมหวัง', 'ot2', 'ot2');
 INSERT INTO `ot` VALUES (3, '3', 4, 'สมปรอง', 'ot3', 'ot3');
 INSERT INTO `ot` VALUES (4, '6', 6, 'สมจิต', 'ot6', 'ot6');
 INSERT INTO `ot` VALUES (5, '7', 4, 'สำเริง', 'ot7', 'ot7');
 
 |  
              | 
                
                  |  |  |  |  
                  |  | 
                      
                        | Date :
                            2012-05-28 10:51:50 | By :
                            บู้ |  |  |  
                  |  |  |  |  |  |  |  
          |  |  |  |  |  
 
        
          |  |  |  |  |  
          |  |  | 
            
              | หลักการของ code ให้ได้กราฟข้างบนนั้นก็แค่คิวรี่ข้อมูลออกมาให้มี Value เข้ามาใส่ใน array เท่านั้น ผมถึงได้บอกว่าเอา Value ที่ต้องการ ซึ่งในที่นี้ก็คือฟิลดิ์ "count_ot_id" ซึ่ง jpgraph มันจะเอาข้อมูล (Value) ที่ได้ไปใส่ใน Array หมายความว่ามันใช้ข้อมูลฟิลดิ์เดียวไปใช้เท่านั้น ... 
 เพราะฉะนั้นไม่ว่าจะคิวรี่มาแบบไหน Join กันเท่าไหร่ก็แค่ให้ผลลัพธ์ออกมาอย่างน้อยฟิลดิ์เดียวก็พอ ... เพื่อใช้เป็น Value สำหรับ Create a bar pot
 
 คำถามต่อไปคือ ถ้าต้องการ Joint table เพื่อที่จะเอาชื่อที่อยู่ในฟิลดิ์อีกฟิลดิ์เข้ามาใช้สำหรับแกนแนวนอนจะทำอย่างไรใช่มั้ยครับ... ออกตัวไว้ก่อนว่าผมไม่เคยใช้ Jpgraph
 
 เพราะฉะนั้นเราต้องคิวรี่ให้ออกมาสองฟิลดิ์ ( 2 คอลัมน์) นั่นล่ะครับ ประมาณนี้
 
 Code (PHP)
 
 SELECT o.ot_user as ot_user, Count(t.ot_id) as count_ot_id 
FROM therapy AS t
Inner Join ot AS o ON o.ot_id = t.ot_id
GROUP BY o.ot_user
 
 แล้วเราก็ต้องเอาทั้ง 2 ฟิลดิ์ไปใช้ใน array คนละตัวกันนะครับ เพื่อสร้างแกนแนวนอนด้วย ผมไม่แน่ใจว่าอันนี้หรือเปล่านะครับ ที่จะต้องเอา array ของฟิลดิ์แกนนอนไปใช้
 
 Code (PHP)
 
 $graph->xaxis->SetTickLabels($datax);
 
 |  
              | 
 ประวัติการแก้ไข
 2012-05-28 13:55:05
 
                
                  |  |  |  |  
                  |  | 
                      
                        | Date :
                            2012-05-28 13:54:17 | By :
                            Songkram |  |  |  
                  |  |  |  |  |  |  |  
          |  |  |  |  |  
 
        
          |  |  |  |  |  
          |  |  | 
            
              | ขอขอบคุณอีกครั้งครับ ขอบคุณมากเลยครับ แล้วพอจะมีตัวอย่างที่ไม่ใช่ Jpgraph ที่มันง่ายกว่านี้หรือสามารถออกรายงานได้ตามที่ต้องการไหมครับ เพราะผมต้อง query ออกเป็นรายเดือนอีก ดูมันจะยากมากจริง ๆ 
 |  
              | 
 ประวัติการแก้ไข
 2012-05-28 18:35:38
 2012-05-28 18:37:07
 2012-05-28 18:37:33
 
                
                  |  |  |  |  
                  |  | 
                      
                        | Date :
                            2012-05-28 14:22:59 | By :
                            บู้ |  |  |  
                  |  |  |  |  |  |  |  
          |  |  |  |  |  
 
        
          |  |  |  |  |  
          |  |  | 
            
              | ได้แล้วครับ ขอบคุณมากเลย แต่ที่นี้จะออกเป็นรายเดือนยังไงครับ จะใช้ WHERE ได้เลยหรือเปล่า แล้วฐานข้อมูลเป็น 0000-00-00 แบบนี้ใช้ได้เลยไหมครับ ที่คิดไว้จะเอา jumpmenu มาช่วยตอนแสดงผล โดย query ตามจำนวนเดือน แต่มันจะมีปัญหาตอนรายปี ถ้าทำแบบกราฟอันที่ 2 ในคห.1 จะ query ยากขึ้นไปอีกหรือเปล่าครับ กราฟ
 
  โค้ด
 
 <?php
		include("config.php");
		include (".../jpgraph/jpgraph.php");
		include (".../jpgraph/jpgraph_bar.php");
		
		// ติดต่อ ฐานข้อมูล เลือกข้อมูลขึ้นมาเพื่อแสดงกราฟ
		$strSQL = "SELECT o.ot_user as ot_user, Count(t.ot_id) as count_ot_id FROM therapy AS t INNER JOIN ot AS o ON o.ot_id = t.ot_id
		GROUP BY o.ot_user";
		$objQuery = mysql_query($strSQL) or die ("Error Query [".$strSQL."]");
		// เตรียมข้อมุลที่จะแสดง เพื่อสร้างกราฟ
		//$datay=array();
		while($objResult = mysql_fetch_array($objQuery))
		{
		$datay[] = $objResult["count_ot_id"];
		$datax[] = $objResult["ot_user"];
		}
	
		// Create the graph. 
		$graph = new Graph(600,400);    
		
		$graph->SetScale("textlin");
		$graph->SetMarginColor('navy:1.9');
		$graph->SetBox();
		// Create and add a new text
		$txt=new Text('ทดสอบ');
		$txt->SetPos(10,20);
		$txt->SetColor('darkred');
		$txt->SetFont(FF_ANGSA,FS_BOLD,15);
		$txt->SetBox('yellow','navy','[email protected]');
		$graph->AddText($txt);
		// Setup the titles
		$graph->title->Set('ทดสอบ');
		$graph->xaxis->title->Set('แกน-X');
		$graph->yaxis->title->Set('แกน-Y');
		$graph->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->yaxis->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->xaxis->title->SetFont(FF_ANGSA,FS_BOLD,18);
		$graph->title->Set('ทดสอบ');
		$graph->title->SetFont(FF_ANGSA,FS_BOLD,20);
		$graph->SetTitleBackground('lightblue:1.3',TITLEBKG_STYLE2,TITLEBKG_FRAME_BEVEL);
		$graph->SetTitleBackgroundFillStyle(TITLEBKG_FILLSTYLE_HSTRIPED,'lightblue','blue');
		//Setup X-scale 
		 //$graph->xaxis->SetTextTickInterval(10); 
		//$graph->xaxis->SetTickLabels($datax); 
		//$graph->xtick_factor = 1; 
		//$graph->xaxis->SetLabelAngle(30); 
		//$graph->xaxis->SetTickLabels(array('OT1','OT2','OT3','OT6','OT7'));
		$graph->xaxis->SetTickLabels($datax);
		// Create a bar pot
		$bplot = new BarPlot($datay);
		$bplot->SetFillColor('darkorange');
		$bplot->SetWidth(0.6);
		$bplot->SetPattern(PATTERN_CROSS1,'navy');
		$graph->Add($bplot);
		$graph->Stroke();
?>
 |  
              | 
                
                  |  |  |  |  
                  |  | 
                      
                        | Date :
                            2012-05-28 16:45:26 | By :
                            บู้ |  |  |  
                  |  |  |  |  |  |  |  
          |  |  |  |  |  |  |