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 > .NET Framework > Forum > [MySQL] ติดปัญหาการคิดคำนวนผลรวม รบกวนผู้รู้ชี้แนะด้วยครับ



 

[MySQL] ติดปัญหาการคิดคำนวนผลรวม รบกวนผู้รู้ชี้แนะด้วยครับ

 



Topic : 130483



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



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




คือตอนนี้ผมติดปัญหาเรื่องของการนำผล 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));


fddfd



Tag : .NET, MySQL, Ms SQL Server 2012, Web (ASP.NET)









ประวัติการแก้ไข
2018-03-06 14:18:11
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2018-03-06 14:16:29 By : chetlove08 View : 1384 Reply : 10
 

 

No. 1



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



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

แบบนี้รึป่าว
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
 


 

No. 2



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



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


ตอบความคิดเห็นที่ : 1 เขียนโดย : lamaka.tor เมื่อวันที่ 2018-03-06 16:06:21
รายละเอียดของการตอบ ::
ขอบคุณครับ .... แต่ค่ามันไม่ออกครับ T-t

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-03-06 17:18:17 By : chetlove08
 

 

No. 3



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



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

ตอบความคิดเห็นที่ : 2 เขียนโดย : chetlove08 เมื่อวันที่ 2018-03-06 17:18:17
รายละเอียดของการตอบ ::
ค่าที่ได้เป็นยังไงบ้างครับ
แล้วมี Error รึปล่าว

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-03-06 17:33:36 By : lamaka.tor
 


 

No. 4



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



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


ตอบความคิดเห็นที่ : 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
 


 

No. 5



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



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


ใช้ subquery ช่วย

หลัก คิวรี่ เฉพาะ ข้อมูลหลัก ไม่ต้อง เอารายการ สุดท้าย
sub เฉพาะ รายการสุดท่าย

เอามา join กัน
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-03-07 11:04:54 By : Chaidhanan
 


 

No. 6



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



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


ตอบความคิดเห็นที่ : 5 เขียนโดย : Chaidhanan เมื่อวันที่ 2018-03-07 11:04:54
รายละเอียดของการตอบ ::
พยายามดูแต่ก็ยัง งง ว่าเราจะเรียกรายสุดท้ายไปใช้งานยังไง พอจะมีตัวอย่างให้ผมลองแกะดูบ้างไหมครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-03-08 11:17:50 By : chetlove08
 


 

No. 7



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



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


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
 


 

No. 8



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



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


ตอบความคิดเห็นที่ : 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
 


 

No. 9



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



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


group by ไม่ต้องใส่ วงเล็บครับ ผมแค่ทำเป็นตัวอย่าง
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-03-08 15:40:58 By : Chaidhanan
 


 

No. 10



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



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


ตอบความคิดเห็นที่ : 9 เขียนโดย : Chaidhanan เมื่อวันที่ 2018-03-08 15:40:58
รายละเอียดของการตอบ ::
ขอบคุณมากครับ ตอนนี้ทำได้แล้ว

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-03-08 16:06:45 By : chetlove08
 

   

ค้นหาข้อมูล


   
 

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