  | 
              
	              
	                
  
    |   | 
   
  
    
        
        [MySQL] ติดปัญหาการคิดคำนวนผลรวม รบกวนผู้รู้ชี้แนะด้วยครับ     | 
   
  
    |   | 
   
 
 
 
	
		
			  | 
	   | 
	    | 
		
			  | 
	 
	
		
			  | 
		 		   | 
	  	    
          
            
			
	
			
			 
                คือตอนนี้ผมติดปัญหาเรื่องของการนำผล ROLLUP ที่บรรทัดสุดท้ายมาคำนวนต่อที่ Column ถัดไป  
 
ซึ่งตามความต้องการของผมแล้วคือ ผมต้องการนำ แถวที่ 1 ใน Column total * 100 / ผมรวมที่แถวสุดท้าย ROLLUP (253) 
 
ตอนนี้ผมติดที่ว่าจะเรียก รวมผลบรรทัดสุดท้ายมาคำนวนยังไงอะครับ  
 
รบกวนชี้แนะด้วยนะครับ  
 
Code (SQL) 
SELECT reason_id,reason_name,reason_jan,reason_feb,reason_mar,reason_apr,reason_may,reason_jun,reason_jul,reason_aug,reason_sep,reason_oct,reason_nov,reason_dec, 
SUM(reason_jan+reason_feb+reason_mar+reason_apr+reason_may+reason_jun+reason_jul+reason_aug+reason_sep+reason_oct+reason_nov+reason_dec) as 'total'
FROM REASON GROUP BY ROLLUP ((reason_id,reason_name,reason_jan,reason_feb,reason_mar,reason_apr,reason_may,reason_jun,reason_jul,reason_aug,reason_sep,reason_oct,reason_nov,reason_dec));
  
 
 
 
 
  Tag : .NET, MySQL, Ms SQL Server 2012, Web (ASP.NET)               
                        | 
           
          
            
		
  ประวัติการแก้ไข 2018-03-06 14:18:11	
                             | 
           
          
            
              
                   | 
                   | 
                   | 
               
              
                   | 
                
                    
                      | Date :
                          2018-03-06 14:16:29 | 
                      By :
                          chetlove08 | 
                      View :
                          1672 | 
                      Reply :
                          10 | 
                     
                  | 
                   | 
               
              
                   | 
                   | 
                   | 
               
              | 
           
          
            | 
			 | 
           
         
	    
		             | 
		
			  | 
	 
	
		
			  | 
		  | 
		
			  | 
		
			  | 
	 
 
              
  
          
		
     
		
	  
        
             | 
            | 
            | 
             | 
         
        
             | 
                       | 
          
            
               
                 แบบนี้รึป่าว 
Code (SQL) 
SELECT reason_id,reason_name,reason_jan,reason_feb,reason_mar,reason_apr,reason_may,reason_jun,reason_jul,reason_aug,reason_sep,reason_oct,reason_nov,reason_dec, 
SUM(reason_jan+reason_feb+reason_mar+reason_apr+reason_may+reason_jun+reason_jul+reason_aug+reason_sep+reason_oct+reason_nov+reason_dec) as _total,total * 100 /_total As _sum 
FROM REASON GROUP BY ROLLUP ((reason_id,reason_name,reason_jan,reason_feb,reason_mar,reason_apr,reason_may,reason_jun,reason_jul,reason_aug,reason_sep,reason_oct,reason_nov,reason_dec));
  
 
total ในตารางมันมีอยู่แล้ว ถ้า As total มันจะ งงๆนะครับ                        
               
               | 
             
            
              
			                              
                              
              
                
                     | 
                     | 
                     | 
                 
                
                     | 
                  
                      
                        | Date :
                            2018-03-06 16:06:21 | 
                        By :
                            lamaka.tor | 
                         
                    | 
                     | 
                 
                
                     | 
                     | 
                     | 
                 
                | 
             
           
			         | 
             | 
         
        
             | 
            | 
             | 
             | 
         
          
	    
     
               
		
     
		
	     
	    
     
               
		
     
		
	     
	    
     
               
		
     
		
	  
        
             | 
            | 
            | 
             | 
         
        
             | 
                       | 
          
            
               
                   ตอบความคิดเห็นที่ : 3 เขียนโดย : lamaka.tor เมื่อวันที่ 2018-03-06 17:33:36 
รายละเอียดของการตอบ ::
  ผมลองเอาคำสั่งที่   ตอบความคิดเห็นที่ : 3 เขียนโดย : lamaka.tor เมื่อวันที่ 2018-03-06 17:33:36
รายละเอียดของการตอบ ::
  ผมลองเอาคำสั่งที่ให้มาไปรับ แล้วเหมือนไม่อ่านค่า _total อะครับ 
 
Error converting data type varchar to float.
 
คำสั่งที่ผมลองเอาไปรัน 
 
SELECT reason_id,reason_name,reason_jan,reason_feb,reason_mar,reason_apr,reason_may,reason_jun,reason_jul,reason_aug,reason_sep,reason_oct,reason_nov,reason_dec,  
SUM(reason_jan+reason_feb+reason_mar+reason_apr+reason_may+reason_jun+reason_jul+reason_aug+reason_sep+reason_oct+reason_nov+reason_dec) as _total,total * 100 /_total As _sum 
 
FROM REASON GROUP BY ROLLUP ((reason_id,reason_name,reason_jan,reason_feb,reason_mar,reason_apr,reason_may,reason_jun,reason_jul,reason_aug,reason_sep,reason_oct,reason_nov,reason_dec));
  
                        
               
               | 
             
            
              
			                              
                              
              
                
                     | 
                     | 
                     | 
                 
                
                     | 
                  
                      
                        | Date :
                            2018-03-07 10:25:07 | 
                        By :
                            chetlove08 | 
                         
                    | 
                     | 
                 
                
                     | 
                     | 
                     | 
                 
                | 
             
           
			         | 
             | 
         
        
             | 
            | 
             | 
             | 
         
          
	    
     
               
		
     
		
	  
        
             | 
            | 
            | 
             | 
         
        
             | 
                       | 
          
            
               
                 ใช้ subquery ช่วย 
 
หลัก คิวรี่ เฉพาะ ข้อมูลหลัก ไม่ต้อง เอารายการ สุดท้าย 
sub เฉพาะ รายการสุดท่าย  
 
เอามา join กัน                        
               
               | 
             
            
              
			                              
                              
              
                
                     | 
                     | 
                     | 
                 
                
                     | 
                  
                      
                        | Date :
                            2018-03-07 11:04:54 | 
                        By :
                            Chaidhanan | 
                         
                    | 
                     | 
                 
                
                     | 
                     | 
                     | 
                 
                | 
             
           
			         | 
             | 
         
        
             | 
            | 
             | 
             | 
         
          
	    
     
               
		
     
		
	     
	    
     
               
		
     
		
	  
        
             | 
            | 
            | 
             | 
         
        
             | 
                       | 
          
            
               
                 Code (SQL) 
select x.*, x.total * y. total 
from ( select *, (f1+f2+f3) as total from tbname group by (...)) as x
, (select sum((f1+f2+f3)) as total from tbname) as y
                         
               
               | 
             
            
              
			                
  ประวัติการแก้ไข 2018-03-08 12:45:22              
                              
              
                
                     | 
                     | 
                     | 
                 
                
                     | 
                  
                      
                        | Date :
                            2018-03-08 12:40:01 | 
                        By :
                            Chaidhanan | 
                         
                    | 
                     | 
                 
                
                     | 
                     | 
                     | 
                 
                | 
             
           
			         | 
             | 
         
        
             | 
            | 
             | 
             | 
         
          
	    
     
               
		
     
		
	  
        
             | 
            | 
            | 
             | 
         
        
             | 
                       | 
          
            
               
                   ตอบความคิดเห็นที่ : 7 เขียนโดย : Chaidhanan เมื่อวันที่ 2018-03-08 12:40:01 
รายละเอียดของการตอบ ::
  
Code (SQL)
SELECT x.*,x.total * y.total
from (select *, (reason_jan+reason_feb+reason_mar+reason_apr+reason_may+reason_jun+reason_jul+reason_aug+reason_sep+reason_oct+reason_nov+reason_dec) as total from REASON group by (reason_jan,reason_feb,reason_mar,reason_apr,reason_may,reason_jun,reason_jul,reason_aug,reason_sep,reason_oct,reason_nov,reason_dec) as x
, (select sum((reason_jan+reason_feb+reason_mar+reason_apr+reason_may+reason_jun+reason_jul+reason_aug+reason_sep+reason_oct+reason_nov+reason_dec)) as total from REASON ) as y
 
ทำไมมันถึงเกิด Error  ' , ' ที่เกิดคำสั่ง GROUP BY อะครับ เหมือน syntax มันผิด หรือว่าผมเขียนตรงไหนผิดพลาดครับ
                         
               
               | 
             
            
              
			                              
                              
              
                
                     | 
                     | 
                     | 
                 
                
                     | 
                  
                      
                        | Date :
                            2018-03-08 14:58:48 | 
                        By :
                            chetlove08 | 
                         
                    | 
                     | 
                 
                
                     | 
                     | 
                     | 
                 
                | 
             
           
			         | 
             | 
         
        
             | 
            | 
             | 
             | 
         
          
	    
     
               
		
     
		
	  
        
             | 
            | 
            | 
             | 
         
        
             | 
                       | 
          
            
               
                 group by ไม่ต้องใส่ วงเล็บครับ ผมแค่ทำเป็นตัวอย่าง                        
               
               | 
             
            
              
			                              
                              
              
                
                     | 
                     | 
                     | 
                 
                
                     | 
                  
                      
                        | Date :
                            2018-03-08 15:40:58 | 
                        By :
                            Chaidhanan | 
                         
                    | 
                     | 
                 
                
                     | 
                     | 
                     | 
                 
                | 
             
           
			         | 
             | 
         
        
             | 
            | 
             | 
             | 
         
          
	    
     
               
		
     
		
	     
	    
     
      		  
	
     | 
   
 
                 |