580 likes | 719 Views
Chapter 1 Basic SELECT Statements. Overview Section A: Fundamentals Column Selections and Aliases Expressions in Calculated Columns Special Cases Ordering the Results. Overview (continued).
E N D
Chapter 1 Basic SELECT Statements Overview Section A: Fundamentals • Column Selections and Aliases • Expressions in Calculated Columns • Special Cases • Ordering the Results
Overview (continued) Section B: Row Selection With The Where Clause • Comparisons • Special Operators • Logical Operators • Substitution Parameters
The Basic SELECT Statement SELECT column-list FROM table-name; where 1)column-list consists of one or more column names separated by commas. If all columns are to be included, then an asterisk may be used for the list. and 2) table-name is the name of the table.
Selection of All Columns SELECT * FROM customer; C_ID PHONE LNAME FNAME CURR_BAL DUEDATE ---------- -------- ---------- ---------- ---------- --------- 388 549-6730 Woolard Jessica 402 529-8420 St. James Ellen 4.99 03-JUL-03 673 549-8400 Akers Janet 9.97 23-JUN-03 579 549-1234 Poston Blaine 799 549-6711 Ackers John 1.99 01-JUL-03 767 453-8228 Ralston Cheri 14.9 30-JUN-03 133 453-2271 Akers Leita 20.18 02-JUL-03 239 549-1235 Macke Greg 400 549-8440 Salyers Loretta 5 06-JUL-03 701 549-8840 Williams Tisha 20 28-JUN-03 10 rows selected.
Specification of a Column List SELECT c_id, phone, lname, fname, curr_bal, duedate FROM customer; C_ID PHONE LNAME FNAME CURR_BAL DUEDATE ---------- -------- ---------- ---------- ---------- --------- 388 549-6730 Woolard Jessica 402 529-8420 St. James Ellen 4.99 03-JUL-03 673 549-8400 Akers Janet 9.97 23-JUN-03 579 549-1234 Poston Blaine 799 549-6711 Ackers John 1.99 01-JUL-03 767 453-8228 Ralston Cheri 14.9 30-JUN-03 133 453-2271 Akers Leita 20.18 02-JUL-03 239 549-1235 Macke Greg 400 549-8440 Salyers Loretta 5 06-JUL-03 701 549-8840 Williams Tisha 20 28-JUN-03 10 rows selected.
Column Aliases • Used to display improved column headings • Alias is listed immediately following the column name in the list (before the comma) • Default display is all capital letters • Use double quotes for different letter case usage and/or special characters
Column Aliases SELECT c_id "Cust. ID", phone PhoneNo, duedate "Due Date" FROM customer; Cust. ID PHONENO Due Date ---------- -------- --------- 388 549-6730 402 529-8420 03-JUL-03 673 549-8400 23-JUN-03 579 549-1234 799 549-6711 01-JUL-03 767 453-8228 30-JUN-03 133 453-2271 02-JUL-03 239 549-1235 400 549-8440 06-JUL-03 701 549-8840 28-JUN-03 10 rows selected.
Expressions in Calculated Columns Numeric Expressions • Operators: + - * / • Multiplication and division are evaluated before addition and subtraction. • Precedence can be overridden by using parentheses.
Numeric Expression in a Calculated Column For each doctor, display his or her name and annual income. SELECT doc_name, salpermon * 12 + annual_bonus FROM doctor; DOC_NAME SALPERMON*12+ANNUAL_BONUS --------- ------------------------- Harrison 148500 Vester Lewis 122250 Cotner 145500 Smith 56850 James 101900 James 125300 Robertson 134000 Thompson 81200 Pronger Borque 204500 Stevenson 12 rows selected.
Addition of Column Alias SELECT doc_name, salpermon * 12 + annual_bonus "ANNUAL INCOME" FROM doctor; DOC_NAME ANNUAL INCOME --------- ------------- Harrison 148500 Vester Lewis 122250 Cotner 145500 Smith 56850 James 101900 James 125300 Robertson 134000 Thompson 81200 Pronger Borque 204500 Stevenson 12 rows selected.
Character Expressions • The concatenation operator (||) is used to join two character strings. • The character strings can come either from existing columns or from literal strings enclosed in single quotes.
Character Expression in a Calculated Column Display each patient's name and street address in sentence form. SELECT pt_fname || ' ' || pt_lname || ' was born on ' || ptdob || '.' "PATIENT INFORMATION" FROM patient; PATIENT INFORMATION -------------------------------------------- Paul James was born on 14-MAR-97. Brian Anderson was born on 06-MAR-48. Scott James was born on 01-MAR-33. Jason Smith was born on 12-DEC-99. Susan Porter was born on 14-NOV-67. (and so on)
Date Expressions • The built-in function SYSDATE returns the current date. • This can be displayed by itself by using a dummy table named DUAL. SELECT SYSDATE FROM DUAL; SYSDATE --------- 01-JUL-03
Date Expressions • One date can be subtracted from another date to determine the number of days between the two dates. • Additionally, integers can be added or subtracted from dates, giving a new date.
Date Expressions Determine the number of days that have elapsed since each patient's last visit. SELECT pt_lname, pt_fname, sysdate – lastapptdate "DAYS SINCE LAST VISIT" FROM patient; PT_LNAME PT_FNAME DAYS SINCE LAST VISIT --------------- --------------- --------------------- James Paul 30 Anderson Brian 30 James Scott 11 Smith Jason 47 Porter Susan 122 (and so on)
Special Cases -- Null Values If null (empty) values are included in an expression, the result will be null. For each doctor, display his or her name and annual income. SELECT doc_name, salpermon * 12 + annual_bonus FROM doctor; DOC_NAME SALPERMON*12+ANNUAL_BONUS --------- ------------------------- Harrison 148500 Vester Lewis 122250 Cotner 145500 Smith 56850 James 101900 James 125300 Robertson 134000 Thompson 81200 Pronger Borque 204500 Stevenson 12 rows selected.
Special Cases -- Duplicate Values • Duplicate rows can be eliminated from results by using DISTINCT before the column name.
Ordering the Results • The ORDER BY clause is used to arrange the rows in the results of a query in a specific order. • The actual order within the table does not change. • The ORDER BY clause is added after the FROM clause.
General Syntax of the ORDER BY Clause: ORDER BY expression [DESC] • where the expression may consist of a column name, column alias, or calculated expression • and the default order is ascending • optionally include DESC for descending
The ORDER BY Clause Display all doctor's names and hire dates in chronological order with the person on staff the longest listed first. SELECT doc_name, datehired FROM doctor ORDER BY datehired;
The ORDER BY Clause DOC_NAME DATEHIRED --------- --------- Stevenson 30-JUN-79 Borque 30-JUN-89 Harrison 05-DEC-94 Robertson 02-MAR-95 James 02-MAY-95 Lewis 21-JAN-96 Thompson 18-MAR-97 Cotner 16-JUN-98 Smith 22-JUN-98 James 01-AUG-98 Pronger 18-DEC-99 Vester 09-JAN-00 12 rows selected.
The ORDER BY Clause Modify the previous example to begin the list with the person on staff for the shortest time. SELECT doc_name, datehired FROM doctor ORDER BY datehired DESC;
The ORDER BY Clause DOC_NAME DATEHIRED --------- --------- Vester 09-JAN-00 Pronger 18-DEC-99 James 01-AUG-98 Smith 22-JUN-98 Cotner 16-JUN-98 Thompson 18-MAR-97 Lewis 21-JAN-96 James 02-MAY-95 Robertson 02-MAR-95 Harrison 05-DEC-94 Borque 30-JUN-89 Stevenson 30-JUN-79 12 rows selected.
Multi-level Sort • A multiple-level sort can be specified by listing more than one expression with commas for separators. • The DESC specification may be included on each expression individually.
Multi-level Sort Display all movie data in category order. Within a category, display titles in alphabetic order. SELECT * FROM movie ORDER BY category, title;
Multi-level Sort M_ID FEE TITLE CATEGORY ---------- ---------- -------------------- ---------- 233 2.99 Gone in 60 Seconds Action 216 2.99 Ocean's Eleven Action 249 1.99 U-571 Action 289 1.99 The Royal Tenenbaums Comedy 304 2.99 Wild, Wild West Comedy 320 1.99 A Beautiful Mind Drama 349 1.99 Cast Away Drama 204 1.99 City of Angels Drama 324 2.99 Field of Dreams Family 316 .99 Horse Whisperer Drama 278 1.99 Monster's Ball Drama 254 2.99 Road to Perdition Drama 255 2.99 Amelie Foreign 325 2.99 Beautiful Life Foreign 315 2.99 Himalaya Foreign 237 .99 E.T. Kids 236 .99 Monsters, Inc. Kids 355 1.99 Spiderman Kids 287 2.99 A Knight's Tale 337 1.99 Grease 354 2.99 O Brother 21 rows selected.
Section B: Row Selection With The Where Clause • Comparisons • Special Operators • Logical Operators • Substitution Parameters
The Where Clause • The WHERE clause can be added to the SELECT statement to restrict the results to rows that satisfy a specified condition. • Rows that do not meet the condition will not be included in the results.
Comparisons General syntax for comparisons: expression comparison-operator expression where an expression consists of a column name, literal value, or some combination involving operators (+, -, *, /, ||) and comparison-operators are >, <, =, >=, <=, and <>
Comparisons • The two expressions must be of the same type • Character string literals should be enclosed in single quotes • Date literals should be of the form 'DD-MON-YY' • Numeric literals should consist of digits and optionally, a decimal and/or sign (no commas or dollar signs)
Special Operators Several special operators serve as shortcuts for longer expressions. One is the BETWEEN operator. • It is used to determine whether or not a value lies within a specific range (including the end points) • General syntax: expression1 BETWEEN expression2 AND expression 3
The BETWEEN Operator Display the IDs and balances of patients that owe at least $300 and no more than $500. SELECT pt_id, balance FROM billing WHERE balance BETWEEN 300 AND 500; PT_ID BALANCE --------- --------- 331 300 809 450 307 450 439 500
The IN Operator • Used to see if a value occurs in a set of possible values • The set of possible values is specified within parentheses with commas between values
The IN Operator Display all current rental data for movies 255, 354, and 315. SELECT * FROM rental WHERE m_id IN (255, 354, 315); C_ID M_ID DATE_OUT DUE_DATE ---------- ---------- --------- --------- 400 255 29-JUN-03 01-JUL-03 400 354 29-JUN-03 30-JUN-03 579 354 01-JUL-03 04-JUL-03
The IS NULL Operator • Any comparison to a null value that uses the standard comparison operators will not yield a match. • If a check for null values is needed, the IS NULL operator must be used.
The IS NULL Operator Display the IDs of doctors that do not receive annual bonuses. SELECT doc_id FROM doctor WHERE annual_bonus IS NULL; DOC_ID --------- 509 239 100
The LIKE Operator • Used in conjunction with wildcard characters to match character string patterns • % is used to match zero or more characters • _ is used to match a single character • Wildcards cannot be used without the LIKE operator • The LIKE operator should not be used without wildcards
The LIKE Operator Display the full name and phone number for customers whose phone number begins with 549-67 SELECT lname || ', ' || fname "FULL NAME", phone FROM customer WHERE phone LIKE '549-67__' ; FULL NAME PHONE ---------------------- -------- Woolard, Jessica 549-6730 Ackers, John 549-6711
The LIKE Operator Display the ID, balance, and due date for customers with balances due in June. SELECT c_id, curr_bal, duedate FROM customer WHERE duedate LIKE '%JUN%'; C_ID CURR_BAL DUEDATE ---------- ---------- --------- 673 9.97 23-JUN-03 767 14.9 30-JUN-03 701 20 28-JUN-03
Logical Operators • 3 standard logical operators (AND, OR, and NOT) are used to combine expressions • AND will return a value of true only if both expressions are true • OR will return a value of true if either or both of the expressions are true • NOT will return the opposite value of the expression. • Order of precedence: NOT, AND, OR
Logical Operators Display IDs and balances for patients who either have balances of more than $90,000 or have insurance with SIH. SELECT pt_id, balance, pt_ins FROM billing WHERE balance > 90000 OR pt_ins = 'SIH'; PT_ID BALANCE PT_INS -------- ---------- -------- 168 15650 SIH 816 0 SIH 847 98000 BCBS 966 98700 BCBS 669 128450 BCBS
Logical Operators Display all data on movies either in the Action category with fees under $2.99 or in some other category with fees over $1.99. SELECT * FROM movie WHERE category = 'Action' AND fee < 2.99 OR category <> 'Action' AND fee > 1.99; M_ID FEE TITLE CATEGORY ---------- ---------- -------------------- ---------- 249 1.99 U-571 Action 254 2.99 Road to Perdition Drama 255 2.99 Amelie Foreign 304 2.99 Wild, Wild West Comedy 315 2.99 Himalaya Foreign 324 2.99 Field of Dreams Family 325 2.99 Beautiful Life Foreign 7 rows selected.
Logical Operators Display all data on customers except those with a last name of Akers, Ackers, or Macke. SELECT * FROM customer WHERE NOT lname IN ('Akers', 'Ackers', 'Macke'); C_ID PHONE LNAME FNAME CURR_BAL DUEDATE ---------- -------- ---------- ---------- ---------- --------- 388 549-6730 Woolard Jessica 402 529-8420 St. James Ellen 4.99 03-JUL-03 579 549-1234 Poston Blaine 767 453-8228 Ralston Cheri 14.9 30-JUN-03 400 549-8440 Salyers Loretta 5 06-JUL-03 701 549-8840 Williams Tisha 20 28-JUN-03 6 rows selected.
Other NOT Operators • The NOT operator can also be used in conjunction with the special operators as follows: • NOT BETWEEN • NOT IN • IS NOT NULL • NOT LIKE
Other NOT Operators Display all data on movies other than those that cost between $1.99 and $2.99. SELECT * FROM movie WHERE fee NOT BETWEEN 1.99 AND 2.99; M_ID FEE TITLE CATEGORY ---------- ---------- -------------------- ---------- 236 .99 Monsters, Inc. Kids 237 .99 E.T. Kids 316 .99 Horse Whisperer Drama
Substitution Parameters • Allows the user to enter a value before a query is executed • Has effect of allowing the results to be customized at execution time • An additional SQL Plus command is used to provide the user with a prompt (ACCEPT) • ACCEPTs are included at the beginning of the script file along with the SELECT command