Error: Invalid expression in the select list (not contained in either an aggregate function or the GROUP BY clause)

前端 未结 3 1038
花落未央
花落未央 2020-12-21 18:02

I am using Firebird SQL. The below mentioned query returns 4 rows as shown in the figure.

    SELECT a.EPS_ID,b.C_NAME,c.AY_YR_NAME,d.S_NAME,e.E_NAME
FROM 
          


        
相关标签:
3条回答
  • 2020-12-21 18:26

    Try

    SELECT a.EPS_ID,c.AY_YR_NAME,d.S_NAME,e.E_NAME,MAX(b.C_NAME) AS XT ...
    GROUP BY 1,2,3,4
    
    0 讨论(0)
  • 2020-12-21 18:45

    The usage of GROUP BY makes the engine group the records for you. To do grouping, you have to give advice to the RDBMS for each column, what it should do.

    • Group it? -> Add column to GROUP BY-Clause
    • Not group it? -> ok, what else?
      • ignore the column? remove it from your select-clause
      • Sum it? -> use SUM(mycol)
      • other aggregation functions can be found in the documentation

    Additionally: In your case you try to group by EPS_ID, which is unique in each row. So a grouping by that column will return all rows, because there is nothing to group by. To group records, they have to have the same value.

    0 讨论(0)
  • 2020-12-21 18:49

    Learn to use proper, explicit JOIN syntax.

    Your problem is that all unaggregated columns need to be in the GROUP BY:

    SELECT a.EPS_ID, MAX(b.C_NAME) AS XT, c.AY_YR_NAME, d.S_NAME, e.E_NAME
    FROM TBLEXAMPLANNER_S_MSB a JOIN 
         TBLCLASS_MSB b
         ON a.EPS_CLASS_ID = b.C_ID JOIN
         TBLACADEMICYEAR_MSB c
         ON a.EPS_SESSION_ID = c.AY_ID JOIN
         TBLSUBJECTS_MSB d
         ON a.EPS_SUB_ID = d.S_ID JOIN 
         TBLEXAMTYPE_MSB e
         ON a.EPS_PE_ID = e.E_ID
    GROUP BY a.EPS_ID, c.AY_YR_NAME, d.S_NAME, e.E_NAME;
    

    Note: I would also recommend that you use table abbreviations for table aliases. So, ep for TBLEXAMPLANNER_S_MSB instead of a. Arbitrary table aliases make the query hard to follow.

    0 讨论(0)
提交回复
热议问题