 |
|
[.NET]
[MySQL] ติดปัญหาการคิดคำนวนผลรวม รบกวนผู้รู้ชี้แนะด้วยครับ |
|
 |
|
|
 |
 |
|
คือตอนนี้ผมติดปัญหาเรื่องของการนำผล ROLLUP ที่บรรทัดสุดท้ายมาคำนวนต่อที่ Column ถัดไป
ซึ่งตามความต้องการของผมแล้วคือ ผมต้องการนำ แถวที่ 1 ใน Column total * 100 / ผมรวมที่แถวสุดท้าย ROLLUP (253)
ตอนนี้ผมติดที่ว่าจะเรียก รวมผลบรรทัดสุดท้ายมาคำนวนยังไงอะครับ
รบกวนชี้แนะด้วยนะครับ
Code (SQL)
1. 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,
2. 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'
3.
4. 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 :
1569 |
Reply :
10 |
|
 |
 |
 |
 |
|
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
แบบนี้รึป่าว
Code (SQL)
1. 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,
2. 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
3.
4. 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 |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
ตอบความคิดเห็นที่ : 7 เขียนโดย : Chaidhanan เมื่อวันที่ 2018-03-08 12:40:01
รายละเอียดของการตอบ ::
Code (SQL)
1. SELECT x.*,x.total * y.total
2. 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
3. , ( 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 |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
|
|