Introduction to SQL
SQL What is SQL SQL Components Syntax & Conventions SQL Data Types INNER JOIN SELECT Statements
What Is SQL? SQL (Structured Query Language) – Is a standard language to create, modify, manipulate, and query relational database SQL – is traditionally a nonprocedural Language. – A procedural language, like FORTRAN or C, describes instructions to the computer by HOW to proceed. – A nonprocedural language describes WHAT to produce. SQL3 (1999) – contains procedural features—BEGIN-END block, IF statement, functions. SQL is an open standard—not owned by a company
Brief History of SQL Developed by IBM in the 70’s, along with Relational DB Officially released in 1981 as SQL SQL-86 – ANSI (American National Standards Institute) standard – ISO (International Standards Organization) standard SQL-89 (SQL1) SQL-92 (SQL2) SQL-99 (SQL3) New Standards – Support for Internet – Support for XML – Support for Java – Support for OOP
Why Use SQL? SQL can do things Access Design Window cannot – E.g., subquery SQL can be used from other applications – E.g., from MS Excel, VB – Web applicaitions SQL is independent of MS Access
SQL Components DDL (Data Definition Language) – e.g., CREATE TABLE, DROP TABLE DML (Data Manipulation Language) – e.g., SELECT field FROM table DCL (Data Control Language) – e.g., for internal security
DDL CREATE TABLE ALTER TABLE DROP TABLE CREATE INDEX
DML SELECT UNION UPDATE DELETE -- delete a row INSERT INTO -- insert a row SELECT INTO -- select fields into newTable PARAMETER -- allows user to enter information interactively
SELECT Statement with one table SELECT title, price FROM Books Given: Books (bkID, title, price)
SELECT Statement with condition SELECT title, price FROM Books WHERE Books.price >= 25.0
Arranging in Ascending or Descending Order SELECT title, price FROM Books ORDER BY title SELECT title, price FROM Books ORDER BY price DESC
Ordering by More Than One Field SELECT * FROM Books ORDER BY price, title
Your Turn Given: Persons(lastName, firstName, address, city, ZIP, state) Write an SQL statement for a view containing 1.lastName, firstName, state of persons from the state of “AZ” 2.People (all fields) ordered by their last name 3.lastName, firstName, state of persons arranged by the state and then by last name.
SELECT Statement from two tables SELECT Books.title, Books.price, Publishers.pubName FROM Publishers INNER JOIN Book ON Publishers.pubID = Books.pubID; Books bkID title price pubID Publishers pubID pubName
Inner Join bkIDtitlepricepubID 1b12b132 2B22b232 3b32b331 4b42b431 pubIDpubName 1p11 2p21 3p23 4p24 BooksPublishers bkIDTitlePricepubID pubName 1b12b1322p21 2b22b2322p21 3b32b3311p11 4b42b4311p11 Books Inner Join Publishers On Books.pubID = Publishers.pubID
SELECT Statement from Two Tables SELECT Books.title, Books.price, Publishers.pubName FROM Publishers INNER JOIN Book ON Publishers.pubID = Books.pubID WHERE Books.price > 25; Books bkID title price pubID Publishers pubID pubName
Your Turn Given: Books (ISBN, title, price, pubID) Publishers (putID, pubName, pubPhone) Write an SQL statement to return 1. ISBN, title, price, and pubName of all books 2. title, price, pubName of all books published by “Alpha House” 3. Title, price pubName of all books which cost $25 or over and published by “Alpha House”
Syntax and Conventions Case insensitive, but Use UPPERCASE for keywords (convention) Statements can be broken up over multiple lines Each SQL statement ends with a semicolon Capitalize table names (our convention) For Access: BooksAuthors or [Books/Authors}
SQL Data Types BOOLEAN, LOGICAL BYTE, INTEGER COUNTER, AUTOINCREMENT CURRENCY, MONEY DATE, DATETIME SHORT, SMALLINT LONG, INTEGER SINGLE, REAL Yes/No Number size = byte Autonumber, size = long Currency Date/Time Number, size = Integer Number, size = Long Integer Number, size = single SQL Data TypeAccess Field Type
SQL Data Types (cont.) DOUBLE, FLOAT, NUMBER TEXT, CHAR, STRING LONGTEXT, MEMO Number, size = Double TEXT Memo SQL Data TypeAccess Field Type
Joining Tables Books bkID bkTitle pubID Publishers pubID pubName pubPhone Authors auID auName auPone BooksAuthors bkID auID
Inner Join Books INNER JOIN Publishers ON Books.pubID = Publishers.pubID SELECT title, pubName FROM Books INNER JOIN Publishers ON Books.pubID = Publishers.pubID
Nested Joins SELECT Books.title, Authors.auName FROM Books INNER JOIN (Authors INNER JOIN BooksAuthors ON Authors.auID = BooksAuthors.auID) ON Books.ISBN = BooksAuthors.ISBN; Display Book titles and their Authors. Books ISBN title price pubID BooksAuthors bkID auID Authors auID auName
Relating Many Tables Books bkID title price pubID BooksAuthors ISBN auID Authors auID auName Publishers pubID pubName Display book titles, their authors, and their publishers.
Relating Many Tables Books bkID title price pubID BooksAuthors bkID auID Authors auID auName Publishers pubID pubName SELECT Books.title, Authors.auName, Publishers.pubName FROM Authors INNER JOIN (BooksAuthors INNER JOIN (Books INNER JOIN Publishers ON Books.pubID = Publishers.pubID ) ON BooksAuthors.bkID = Books.bkID ) ON Authors.auID = BooksAuthors.auID
Practice with Access Write SQL statements to display the following. Then create Access queries to answer the same questions and check their SQL statements. Display the authors’ names and their phone numbers Display the phone number of author named “Snoopy” Display titles and price of all books which cost $300 or more (Download library2.mdb)
Practice with SQL Display titles and prices of books and their publishers’ names Display the book titles and their authors Display the book tittles, their authors, and their publishers Display titles and prices of books by publisher named “Big House” Display all books by author named “Sleepy” Display books between $20 and $30 and their authors Display books that are less than $20 or more than $30 and their authors
ON Clause Or WHERE Clause ON clause is part of INNER JOIN, LEFT JOIN, & RIGHT JOIN WHERE places conditions on data values to be displayed. (Think of WHERE as a filter to restrict rows--can provide additional restriction.)
ON or WHERE SELECT Books.Title, Publishers.pubName FROM Books INNER JOIN Publishers ON Books.pubID = Publishers.pubID is equivalent to SELECT Books.Title, Publishers.pubName FROM Books, Publishers WHERE Books.pubID = Publishers.pubID;
Can This Be Simplified? SELECT Books.title, Authors.auName, Publishers.pubName FROM Authors INNER JOIN (BooksAuthors INNER JOIN (Books INNER JOIN Publishers ON Books.pubID = Publishers.pubID ) ON BooksAuthors.bkID = Books.bkID ) ON Authors.auID = BooksAuthors.auID
Recall if (cond1) { statement1 } else { if (cont2) { statement2 } else { if (cond3) { statement3 } } } if (cond1){ statement1} else if (cond2){ statement2} else if (cond3){ statement3} Is equivalent to
Analogously… SELECT Books.title, Authors.auName, Publishers.pubName FROM Authors INNER JOIN (BooksAuthors INNER JOIN (Books INNER JOIN Publishers ON Books.pubID = Publishers.pubID ) ON BooksAuthors.bkID = Books.bkID ) ON Authors.auID = BooksAuthors.auID is equivalent to SELECT Books.title, Authors.auName, Publishers.pubName FROM Authors, BooksAuthors,Books, Publishers WHERE Authors.auID = BooksAuthor.auID AND BooksAuthor.bkID = Books.bkID AND Books.pubID = Publishers.pubID
UPDATE Statement First, make a copy of the Books table--so that you can preserve the original table. Change the price of “Iliad” to $50. UPDATE Books2 SET Books2.Price = 50 WHERE BOOKS2.Title="iliad"; What will result from the following? UPDATE Books2 SET Books2.Price = 50;
UPDATE Statement (cont.) Raise the price of all books from publisher “Big House” by 10 % – Note: subquery SELECT pubID FROM Publishers WHERE pubName = “Big House” UPDATE Books SET price = price * 1.1 WHERE Books2.pubID = Subquery
Raise the price of all books from publisher “Big House” by 10 % UPDATE Books2 SET Books2.price = Books2.price * 1.1 WHERE Books2.pubID = (SELECT Publishers.pubID FROM Publishers WEHRE pubName = “Big House”)
Alternately… UPDATE Books2 INNER JOIN Publishers ON Books2.pubID = Publishers.pubID SET Books2.price = price*1.1 WHERE Publishers.pubName=”Big House";
UPDATE with Values from Another Table Update Price column in Books2 table, with new prices from table NewPrices (ISBN, price). UPDATE Books2 INNER JOIN NewPrices ON Books2.ISBN = NewPrices.ISBN SET Books2.price = NewPrices.price WHERE Books2.prices <> NewPrices.price
Previewing Update To check which records will be modified by the UPDATE statement… SELECT Books.* FROM Books INNER JOIN NewPrices ON Books.ISBN = NewPrices.ISBN WHERE BOOKS.Price<>NewPrices.Price;
Your Turn 1. Change Author Shakespeare’s telephone number to “ ” 2. Reduce the price of all books from publisher “Small House” by 5% 3. Raise the price of all books by Author Shakespeare by 5% (solution)solution
Raise by 5% the price of all books by Shakespeare UPDATE Books2 SET bkPrice =1.05 * bkPrice WHERE Books2.bkID IN (SELECT BooksAuthors2.bkID FROM BooksAuthors2, Authors2 WHERE BooksAuthors2.auID = Authors2.auID AND Authors2.auName = "Shakespeare" ) Back
Difference between “=” and “IN” UPDATE Books2 SET bkPrice =1.05 * bkPrice WHERE Books2.bkID = (SELECT BooksAuthors2.bkID... ) UPDATE Books2 SET bkPrice =1.05 * bkPrice WHERE Books2.bkID IN (SELECT BooksAuthors2.bkID FROM BooksAuthors2, Authors2 WHERE BooksAuthors2.auID IN Authors2.auID AND Authors2.auName = "Shakespeare" ) OK if subquery returns only one value Necessary when subquery can return more than one value
INSERT INTO Statement INSERT INTO Books2 VALUES (“ ”, “SQL Is Fun”, 1, 25.00) INSERT INTO Books2 (ISBN, Title) VALUES (“ ”, “Born to Code”)
INSERT INTO Statement (cont.) Given: Publishers2 (pubID, pubName, pubPhone) where pubID is autonumber type Insert a new publisher INSERT INTO Publisher2(pubName, pubPhone) VALUES (“Aloha Press”, “ ”)
Your Turn Add the following record to Books2 ISBN: Title: SQL for Dummies Publisher ID: 3 Price: $35.50 Add the following record to Authors2 auName: Brando auPhone: Add the following record to Publihsers2 pubName: Aina Haina Associates pubPhone: