Oracle Baisc Tutorial

36

description

oracle queries

Transcript of Oracle Baisc Tutorial

Page 1: Oracle Baisc Tutorial
Page 2: Oracle Baisc Tutorial

After completing this lesson, you should be able to do the following: List the capabilities of SQL SELECT statements Execute a basic SELECT statement Differentiate between SQL statements and iSQL*Plus commands

Page 3: Oracle Baisc Tutorial

SelectionProjection

Table 1 Table 2

Table 1Table 1

Join

Page 4: Oracle Baisc Tutorial

SELECT identifies what columns FROM identifies which table

SELECT *|{[DISTINCT] column|expression [alias],...}FROM table;

Page 5: Oracle Baisc Tutorial

SELECT *FROM r_departments;

Page 6: Oracle Baisc Tutorial

SELECT department_id, location_idFROM r_departments;

Page 7: Oracle Baisc Tutorial

SQL statements are not case sensitive. SQL statements can be on one or more lines. Keywords cannot be abbreviated or split

across lines. Clauses are usually placed on separate lines. Indents are used to enhance readability.

Page 8: Oracle Baisc Tutorial

iSQL*Plus: Default heading justification: Center Default heading display: Uppercase

SQL*Plus: Character and Date column headings are

left- justified Number column headings are right-justified Default heading display: Uppercase

Page 9: Oracle Baisc Tutorial

Create expressions with number and date data by using arithmetic operators.

Operator

+

-

*

/

Description

Add

Subtract

Multiply

Divide

Page 10: Oracle Baisc Tutorial

SELECT last_name, salary, salary + 300FROM r_employees;

Page 11: Oracle Baisc Tutorial

Multiplication and division take priority over addition and subtraction.

Operators of the same priority are evaluated from left to right.

Parentheses are used to force prioritized evaluation and to clarify statements.

** // ++ __

Page 12: Oracle Baisc Tutorial

SELECT last_name, salary, 12*salary+100FROM r_employees;

Page 13: Oracle Baisc Tutorial

SELECT last_name, salary, 12*(salary+100)FROM r_employees;

Page 14: Oracle Baisc Tutorial

A null is a value that is unavailable, unassigned, unknown, or inapplicable.

A null is not the same as zero or a blank space.SELECT last_name, job_id, salary, commission_pctFROM r_employees;

Page 15: Oracle Baisc Tutorial

SELECT last_name, 12*salary*commission_pctFROM r_employees;

Arithmetic expressions containing a null value evaluate to null.

Page 16: Oracle Baisc Tutorial

A column alias: Renames a column heading Is useful with calculations Immediately follows the column name - there

can also be the optional AS keyword between the column name and alias

Requires double quotation marks if it contains spaces or special characters or is case sensitive

Page 17: Oracle Baisc Tutorial

SELECT last_name "Name", salary*12 "Annual Salary"FROM employees;

SELECT last_name AS name, commission_pct commFROM r_employees;

Page 18: Oracle Baisc Tutorial

A concatenation operator: Concatenates columns or character

strings to other columns Is represented by two vertical bars (||) Creates a resultant column that is a

character expression

Page 19: Oracle Baisc Tutorial

SELECT last_name||job_id AS "Employees"FROM r_employees;

Page 20: Oracle Baisc Tutorial

A literal is a character, a number, or a date included in the SELECT list.

Date and character literal values must be enclosed within single quotation marks.

Each character string is output once for eachrow returned.

Page 21: Oracle Baisc Tutorial

SELECT last_name ||' is a '||job_id AS "Employee Details"FROM r_employees;

Page 22: Oracle Baisc Tutorial

The default display of queries is all rows, including duplicate rows.SELECT department_idFROM r_employees;

Page 23: Oracle Baisc Tutorial

Eliminate duplicate rows by using the DISTINCT keyword in the SELECT clause.SELECT DISTINCT department_idFROM r_employees;

Page 24: Oracle Baisc Tutorial

SQL statementsOracleserver

Query resultsQuery resultsiSQL*Plus commands

Client

Formatted report

Internet Internet BrowserBrowser

iiSQL*PlusSQL*Plus

Page 25: Oracle Baisc Tutorial

SQLSQLstatementsstatements

SQL • A language• ANSI standard• Keyword cannot be

abbreviated• Statements manipulate

data and table definitions in the database

iiSQL*PlusSQL*Plus• An environment• Oracle proprietary• Keywords can be

abbreviated• Commands do not allow

manipulation of values in the database

• Runs on a browser• Centrally loaded, does not

have to be implemented on each machine

iiSQL*PlusSQL*Pluscommandscommands

Page 26: Oracle Baisc Tutorial

After you log into iSQL*Plus, you can: Describe the table structure Edit your SQL statement Execute SQL from iSQL*Plus Save SQL statements to files and append SQL

statements to files Execute statements stored in saved files Load commands from a text file into the iSQL*Plus Edit window

Page 27: Oracle Baisc Tutorial

From your Windows browser environment:

Page 28: Oracle Baisc Tutorial

3 4 5

6

71

2

8 910

Page 29: Oracle Baisc Tutorial

Use the iSQL*Plus DESCRIBE command to display the structure of a table.

DESC[RIBE] tablename

Page 30: Oracle Baisc Tutorial

DESCRIBE r_employees

Page 31: Oracle Baisc Tutorial

SELECT last_name, hire_date, salaryFROM r_employees; 1

2

Page 32: Oracle Baisc Tutorial

1

D:\temp\emp_sql.htm

2SELECT last_name, hire_date, salaryFROM r_employees;

3

Page 33: Oracle Baisc Tutorial

DESCRIBE employeesSELECT first_name, last_name, job_idFROM r_employees;

1

23

Page 34: Oracle Baisc Tutorial

SELECT *|{[DISTINCT] column|expression [alias],...}FROM table;

In this lesson, you should have learned how to: • Write a SELECT statement that:

– Returns all rows and columns from a table– Returns specified columns from a table– Uses column aliases to give descriptive column

headings

• Use the iSQL*Plus environment to write, save, and execute SQL statements and iSQL*Plus commands.

Page 35: Oracle Baisc Tutorial

This practice covers the following topics: Selecting all data from different tables Describing the structure of tables Performing arithmetic calculations and

specifying column names Using iSQL*Plus

Page 36: Oracle Baisc Tutorial