KEMBAR78
Selecting Data | PDF | Computer Programming | Computing
0% found this document useful (0 votes)
46 views15 pages

Selecting Data

The document discusses the SELECT statement in SQL, which is used to query a database and retrieve data that matches specified criteria. It explains the basic format and components of a SELECT statement, including the columns, tables, and optional WHERE clause. It also provides examples of different types of queries using selection criteria, aggregate functions, and other clauses.

Uploaded by

Ahmed Sartaj
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
46 views15 pages

Selecting Data

The document discusses the SELECT statement in SQL, which is used to query a database and retrieve data that matches specified criteria. It explains the basic format and components of a SELECT statement, including the columns, tables, and optional WHERE clause. It also provides examples of different types of queries using selection criteria, aggregate functions, and other clauses.

Uploaded by

Ahmed Sartaj
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 15

Selecting Data

The select statement is used to query the database and retrieve selected data that match the
criteria that you specify. Here is the format of a simple select statement:

select "column1"
[,"column2",etc]
from "tablename"
[where "condition"];
[] = optional

The column names that follow the select keyword determine which columns will be returned in

*
the results. You can select as many column names that you'd like, or you can use a " " to select
all columns.

The table name that follows the keyword from specifies the table that will be queried to retrieve
the desired results.

The where clause (optional) specifies which data values or rows will be returned or displayed,
based on the criteria described after the keyword where.

Conditional selections used in the where clause:

= Equal
> Greater than
< Less than
>= Greater than or equal
<= Less than or equal
<> Not equal to
LIKE *See note below

The LIKE pattern matching operator can also be used in the conditional selection of the where
clause. Like is a very powerful operator that allows you to select only rows that are "like" what
you specify. The percent sign "%" can be used as a wild card to match any possible character
that might appear before or after the characters specified. For example:

select first, last, city from empinfo where first LIKE 'Er%';

This SQL statement will match any first names that start with 'Er'. Strings must be in single
quotes.

Or you can specify,


select first, last from empinfo where last LIKE '%s';

This statement will match any last names that end in a 's'.

select * from empinfo where first = 'Eric';

This will only select rows where the first name equals 'Eric' exactly.

Sample Table: empinfo


first last id age city state
John Jones 99980 45 Payson Arizona
Mary Jones 99982 25 Payson Arizona
Eric Edwards 88232 32 San Diego California
Mary Ann Edwards 88233 32 Phoenix Arizona
Ginger Howell 98002 42 Cottonwood Arizona
Sebastian Smith 92001 23 Gila Bend Arizona
Gus Gray 22322 35 Bagdad Arizona
Mary Ann May 32326 52 Tucson Arizona
Erica Williams 32327 60 Show Low Arizona
Leroy Brown 32380 22 Pinetop Arizona
Elroy Cleaver 32382 22 Globe Arizona

Enter the following sample select statements in the SQL Interpreter Form at the bottom of this
page. Before you press "submit", write down your expected results. Press "submit", and compare
the results.

select first, last, city from empinfo;


select last, city, age from empinfo where age > 30;

select first, last, city, state from empinfo where first LIKE 'J%';

select * from empinfo;


select first, last, from empinfo where last LIKE '%s';

select first, last, age from empinfo where last LIKE '%illia%';

select * from empinfo where first = 'Eric';


ALL and DISTINCT are keywords used to select either ALL (default) or the "distinct" or
unique records in your query results. If you would like to retrieve just the unique records in
specified columns, you can use the "DISTINCT" keyword. DISTINCT will discard the duplicate
records for the columns you specified after the "SELECT" statement: For example:

SELECT DISTINCT age FROM employee_info;

This statement will return all of the unique ages in the employee_info table.

ALL will display "all" of the specified columns including all of the duplicates. The ALL
keyword is the default if nothing is specified.

Note: The following two tables will be used throughout this course. It is recommended to have
them open in another window or print them out.

Aggregate Functions

MIN returns the smallest value in a given column


MAX returns the largest value in a given column
SUM returns the sum of the numeric values in a given column
AVG returns the average value of a given column
COUNT returns the total number of values in a given column
COUNT(*) returns the number of rows in a table

Aggregate functions are used to compute against a "returned column of numeric data" from your
SELECT statement. They basically summarize the results of a particular column of selected data.
We are covering these here since they are required by the next topic, "GROUP BY". Although
they are required for the "GROUP BY" clause, these functions can be used without the "GROUP
BY" clause. For example:

SELECT AVG(salary)FROM employee;

This statement will return a single result which contains the average value of everything returned
in the salary column from the employee table.

Another example:
SELECT AVG(salary)FROM employee WHERE title = 'Programmer';

This statement will return the average salary for all employee whose title is equal to
'Programmer'

Example:

SELECT Count(*)FROM employee;

This particular statement is slightly different from the other aggregate functions since there isn't
a column supplied to the count function. This statement will return the number of rows in the
employees table.

Example
Review Exercises

1. Select the maximum price of any item ordered in the items_ordered table. Hint: Select the
maximum price only.
2. Select the average price of all of the items ordered that were purchased in the month of
Dec.
3. What are the total number of rows in the items_ordered table?

Exercise #1

SELECT max(price)
FROM items_ordered;

Exercise #2

SELECT avg(price)
FROM items_ordered
WHERE order_date LIKE '%Dec%';

Exercise #3

SELECT count(*)
FROM items_ordered;

GROUP BY clause
The GROUP BY clause will gather all of the rows together that contain data in the specified
column(s) and will allow aggregate functions to be performed on the one or more columns. This
can best be explained by an example:

GROUP BY clause syntax:

SELECT column1,
SUM(column2)

FROM "list-of-tables"

GROUP BY "column-list";

Let's say you would like to retrieve a list of the highest paid salaries in each dept:
SELECT max(salary), dept

FROM employee

GROUP BY dept;

This statement will select the maximum salary for the people in each unique department.
Basically, the salary for the person who makes the most in each department will be displayed.
Their, salary and their department will be returned.

For example, take a look at the items_ordered table. Let's say you want to group everything of
quantity 1 together, everything of quantity 2 together, everything of quantity 3 together, etc. If
you would like to determine what the largest cost item is for each grouped quantity (all quantity
1's, all quantity 2's, all quantity 3's, etc.), you would enter:

SELECT quantity, max(price)

FROM items_ordered

GROUP BY quantity;

Enter the statement in above, and take a look at the results to see if it returned what you were
expecting. Verify that the maximum price in each Quantity Group is really the maximum price.

Example
SELECT COUNT(CustomerID), Country FROM Customers GROUP BY Country;

Result

Multiple Grouping Columns


SELECT COUNT(CustomerID), Country,city FROM Customers GROUP BY Country,city;

ORDER BY clause
ORDER BY is an optional clause which will allow you to display the results of your query in a
sorted order (either ascending order or descending order) based on the columns that you specify
to order by.

ORDER BY clause syntax:

SELECT column1, SUM(column2) FROM "list-of-tables" ORDER BY "column-list" [ASC |


DESC];

This statement will select the employee_id, dept, name, age, and salary from the employee_info
table where the dept equals 'Sales' and will list the results in Ascending (default) order based on
their Salary.

ASC = Ascending Order - default

DESC = Descending Order


For example:

SELECT employee_id, dept, name, age, salary FROM employee_info WHERE dept = 'Sales'
ORDER BY salary;

If you would like to order based on multiple columns, you must seperate the columns with
commas. For example:

SELECT employee_id, dept, name, age, salary

FROM employee_info

WHERE dept = 'Sales'

ORDER BY salary, age DESC

Order by with group by

SELECT COUNT(CustomerID), Country FROM Customers GROUP BY Country


ORDER BY COUNT(CustomerID) DESC;
Combining Conditions & Boolean Operators
The AND operator can be used to join two or more conditions in the WHERE clause. Both sides
of the AND condition must be true in order for the condition to be met and for those rows to be
displayed.

SELECT column1,
SUM(column2)

FROM "list-of-tables"

WHERE "condition1" AND


"condition2";

The OR operator can be used to join two or more conditions in the WHERE clause also.
However, either side of the OR operator can be true and the condition will be met - hence, the
rows will be displayed. With the OR operator, either side can be true or both sides can be true.

For example:

SELECT employeeid, firstname, lastname, title, salary

FROM employee_info

WHERE salary >= 45000.00 AND title = 'Programmer';


This statement will select the employeeid, firstname, lastname, title, and salary from the
employee_info table where the salary is greater than or equal to 50000.00 AND the title is equal
to 'Programmer'. Both of these conditions must be true in order for the rows to be returned in the
query. If either is false, then it will not be displayed.

Although they are not required, you can use paranthesis around your conditional expressions to
make it easier to read:

SELECT employeeid, firstname, lastname, title, salary

FROM employee_info

WHERE (salary >= 45000.00) AND (title = 'Programmer');

Another Example:

SELECT firstname, lastname, title, salary FROM employee_info WHERE (title = 'Sales') OR
(title = 'Programmer');

This statement will select the firstname, lastname, title, and salary from the employee_info table
where the title is either equal to 'Sales' OR the title is equal to 'Programmer'.

HAVING clause
The HAVING clause allows you to specify conditions on the rows for each group - in other
words, which rows should be selected will be based on the conditions you specify. The HAVING
clause should follow the GROUP BY clause if you are going to use it.

HAVING clause syntax:

SELECT column1,
SUM(column2)

FROM "list-of-tables"

GROUP BY "column-list"

HAVING "condition";

HAVING can best be described by example. Let's say you have an employee table containing the
employee's name, department, salary, and age. If you would like to select the average salary for
each employee in each department, you could enter:
SELECT dept, avg(salary)

FROM employee

GROUP BY dept;

But, let's say that you want to ONLY calculate & display the average if their salary is over
20000:

SELECT dept, avg(salary)

FROM employee

GROUP BY dept

HAVING avg(salary) > 20000;

Mathematical Functions
Standard ANSI SQL-92 supports the following first four basic arithmetic operators:

+ addition
- subtraction
* multiplication
/ division
% modulo

The modulo operator determines the integer remainder of the division. This operator is not ANSI
SQL supported, however, most databases support it. The following are some more useful
mathematical functions to be aware of since you might need them. These functions are not
standard in the ANSI SQL-92 specs, therefore they may or may not be available on the specific
RDBMS that you are using. However, they were available on several major database systems
that I tested. They WILL work on this tutorial.

ABS(x) returns the absolute value of x


returns the sign of input x as -1, 0, or 1 (negative, zero, or positive
SIGN(x)
respectively)
MOD(x,y) modulo - returns the integer remainder of x divided by y (same as x%y)
FLOOR(x) returns the largest integer value that is less than or equal to x
CEILING(x) or
returns the smallest integer value that is greater than or equal to x
CEIL(x)
POWER(x,y) returns the value of x raised to the power of y
ROUND(x) returns the value of x rounded to the nearest whole integer
returns the value of x rounded to the number of decimal places specified
ROUND(x,d)
by the value d
SQRT(x) returns the square-root value of x

For example:

SELECT round(salary), firstname

FROM employee_info

This statement will select the salary rounded to the nearest whole value and the firstname from
the employee_info table.

You might also like