Thursday, 9 November 2017

SAP HANA: ORDER BY, GROUP BY and HAVING Clause


SQL ORDER BY Statement

The ORDER BY clause is used in a SELECT statement to sort results either in ascending or descending order. SAP HANA sorts query results in ascending order by default.
Order by should appear at the end of your select statement after your WHERE, GROUP BY and HAVING clauses if any or all of them exist.

Syntax for using SQL ORDER BY clause to sort data is:


SELECT column-list
FROM table_name [WHERE condition]
[ORDER BY column1 [, column2, .. columnN] [DESC or ASC]];

Example: Employee Table
ID
NAME
DEPT
AGE
SALARY
LOCATION
100
Kabil
Electrical
24
25000
Coimbatore
101
Nazeer
Electronics
28
35000
Coimbatore
102
Aravind
Aeronautics
28
35000
Chennai
103
Kalai
Electronics
22
20000
Coimbatore
104
Keerthi
InfoTech
25
30000
Bangalore

For Example:

If you want to sort the employee table by the salary of the employee, the SQL query would be.

CODE 1:

Select "NAME","SALARY" FROM "KABIL_PRACTICE"."DEMO_EMP" ORDER BY "SALARY";
Result:
NAME
SALARY
Kalai
20000
Kabil
25000
Keerthi
30000
Nazeer
35000
Aravind
35000

CODE 2:

Select "NAME","SALARY" FROM "KABIL_PRACTICE"."DEMO_EMP" ORDER BY 1;
Then the above code “1” indicates the 1st Column which we used in our select statement. Here I used “NAME” as a 1st column. So, the results set order by Name.
Result:
NAME
SALARY
Aravind
35000
Kabil
25000
Kalai
20000
Keerthi
30000
Nazeer
35000

CODE 3:

Select "NAME","SALARY" FROM "KABIL_PRACTICE"."DEMO_EMP" ORDER BY "NAME","SALARY";
The query first sorts the result according to name and then displays it. You can also use more than one column in the ORDER BY clause. If you want to sort the employee table by the name and salary.
Result:
NAME
SALARY
Aravind
35000
Kabil
25000
Kalai
20000
Keerthi
30000
Nazeer
35000

To Sort Data in Descending Order

By default, the ORDER BY Clause sorts data in ascending order. If you want to sort the data in descending order, you must explicitly specify it as shown below.

CODE 4:

Select "NAME","SALARY" FROM "KABIL_PRACTICE"."DEMO_EMP" ORDER BY "NAME","SALARY" desc;
The above query sorts only the column 'salary' in descending order and the column 'name' by ascending order.
Result:
NAME
SALARY
Aravind
35000
Kabil
25000
Kalai
20000
Keerthi
30000
Nazeer
35000
If you want to select both name and salary in descending order, the query would be as given below.

CODE 5:

Select "NAME","SALARY" FROM "KABIL_PRACTICE"."DEMO_EMP" ORDER BY "NAME" desc,"SALARY" desc;
Result:
NAME
SALARY
Nazeer
35000
Keerthi
30000
Kalai
20000
Kabil
25000
Aravind
35000

How to use expressions in the ORDER BY Clause?

Expressions in the ORDER BY clause of a SELECT statement.

For example:

If you want to display employee name, current salary, and a 20% increase in the salary for only those employees for whom the percentage increase in salary is greater than 30000 and in descending order of the increased price, the SELECT statement can be written as shown below

CODE 6:

Select "NAME","SALARY","SALARY" * 1.2 as NEW_SALARY FROM "KABIL_PRACTICE"."DEMO_EMP" Where "SALARY" * 1.2 > 30000 ORDER BY NEW_SALARY desc;
Result:
NAME
SALARY
NEW_SALARY
Nazeer
35000
42000
Aravind
35000
42000
Keerthi
30000
36000

SQL GROUP BY Clause

The SQL GROUP BY Clause is used along with the group functions to retrieve data grouped according to one or more columns.
The GROUP BY clause is a SQL command that is used to group rows that have the same values.
The queries that contain the GROUP BY clause are called grouped queries and only return a single row for every grouped item.

For Example:

If you want to know the total amount of salary spent on each department, the query would be:

CODE 1:

Select "DEPT", SUM("SALARY") from "KABIL_PRACTICE"."DEMO_EMP" Group by "DEPT";
Result:
DEPT
SUM(SALARY)
Electrical
25000
Electronics
55000
Aeronautics
35000
InfoTech
30000

NOTE:
The group by clause should contain all the columns in the select list expect those used along with the group functions.

CODE 2:

Select "LOCATION","DEPT", SUM("SALARY") from "KABIL_PRACTICE"."DEMO_EMP" Group by "LOCATION","DEPT";

Result:
LOCATION
DEPT
SUM(SALARY)
Coimbatore
Electrical
25000
Coimbatore
Electronics
55000
Chennai
Aeronautics
35000
Bangalore
InfoTech
30000

SQL GROUP BY with HAVING Clause

Having clause is used to filter data based on the group functions. This is similar to WHERE condition but is used with group functions. Group functions cannot be used in WHERE Clause but can be used in HAVING clause.

For Example:

If you want to select the department that has total salary paid for its employees more than 30000, the SQL query would be like;

CODE 1:

Select "DEPT",SUM("SALARY") from "KABIL_PRACTICE"."DEMO_EMP" Group by "DEPT" Having SUM("SALARY") > 30000 ;
Result:
DEPT
SUM(SALARY)
Electronics
55000
Aeronautics
35000

Note:
We can use Order by at the end of the above code:

CODE 2:

Select "DEPT", SUM("SALARY") from "KABIL_PRACTICE"."DEMO_EMP" Group by "DEPT" Having SUM("SALARY") > 30000 order by "DEPT";

Result:
DEPT
SUM(SALARY)
Aeronautics
35000
Electronics
55000
Note:
When WHERE, GROUP BY and HAVING clauses are used together in a SELECT statement, the WHERE clause is processed first, then the rows that are returned after the WHERE clause is executed are grouped based on the GROUP BY clause.
Finally, any conditions on the group functions in the HAVING clause are applied to the grouped rows before the final output is displayed.


Thank you for visiting my Blog...
Share your Comments...

3 comments:

  1. Really good materials with examples.

    ReplyDelete
  2. Below 2 statements contradict.....

    1. Having clause is used to filter data based on the group functions. This is similar to WHERE condition but is used with group functions. Group functions cannot be used in WHERE Clause but can be used in HAVING clause.

    2. When WHERE, GROUP BY and HAVING clauses are used together in a SELECT statement, the WHERE clause is processed first, then the rows that are returned after the WHERE clause is executed are grouped based on the GROUP BY clause.
    Finally, any conditions on the group functions in the HAVING clause are applied to the grouped rows before the final output is displayed.

    ReplyDelete
  3. Buenos días, en oracle puedo ejecutar este query sin problemas, será factible hacerlo? o cual será la sintaxis correcta.
    select material, concepto, centro, sum( importe ), sum( unidades )
    from (
    SELECT w~matnr AS material, maktx AS concepto, w~bwkey AS centro, a~meins AS umb, SUM( w~salk3 ) AS importe, SUM( w~lbkum ) AS unidades
    FROM mbewh AS w
    INNER JOIN makt AS t ON w~matnr = t~matnr AND spras = 'S'
    INNER JOIN mara AS a ON w~matnr = a~matnr
    INNER JOIN t001k AS k ON k~bwkey = w~bwkey AND k~bukrs = 1300
    WHERE w~bwkey = 1301 and w~lfmon = 12 and w~lfgja = 2019 and w~lbkum > 0
    UNION ALL
    SELECT w~matnr AS material, maktx AS concepto, w~bwkey AS centro, a~meins AS umb, SUM( salk3 ) AS importe, SUM( lbkum ) AS unidades
    FROM ebewh AS w
    INNER JOIN makt AS t ON w~matnr = t~matnr AND spras = 'S'
    INNER JOIN mara AS a ON w~matnr = a~matnr
    INNER JOIN t001k AS k ON k~bwkey = w~bwkey AND k~bukrs = 1300
    WHERE w~bwkey = 1301 and w~lfmon = 12 and w~lfgja = 2019 and w~lbkum > 0 )
    group by material, concepto, centro
    INTO TABLE @DATA(it_datah).

    ReplyDelete