Download presentation
Presentation is loading. Please wait.
Published byIlene Briggs Modified over 9 years ago
1
© 2009 Pearson Education, Inc. Publishing as Prentice Hall 1 Chapter 8 (Part b): Advanced SQL Modern Database Management 9 th Edition Jeffrey A. Hoffer, Mary B. Prescott, Heikki Topi
2
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 2 Conditional Expressions Using Case Syntax This is available with newer versions of SQL, previously not part of the standard Figure 8-8
3
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 3 Tips for Developing Queries Be familiar with the data model (entities and relationships) Be familiar with the data model (entities and relationships) Understand the desired results Understand the desired results Know the attributes desired in result Know the attributes desired in result Identify the entities that contain desired attributes Identify the entities that contain desired attributes Review ERD Review ERD Construct a WHERE for each link Construct a WHERE for each link Fine tune with GROUP BY and HAING clauses if needed Fine tune with GROUP BY and HAING clauses if needed Consider the effect on unusual data Consider the effect on unusual data
4
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 4 Ensuring Transaction Integrity Transaction = A discrete unit of work that must be completely processed or not processed at all Transaction = A discrete unit of work that must be completely processed or not processed at all May involve multiple updates May involve multiple updates If any update fails, then all other updates must be cancelled If any update fails, then all other updates must be cancelled SQL commands for transactions SQL commands for transactions BEGIN TRANSACTION/END TRANSACTION BEGIN TRANSACTION/END TRANSACTION Marks boundaries of a transaction Marks boundaries of a transaction COMMIT COMMIT Makes all updates permanent Makes all updates permanent ROLLBACK ROLLBACK Cancels updates since the last COMMIT Cancels updates since the last COMMIT
5
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 5 Figure 8-9 An SQL Transaction sequence (in pseudocode)
6
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 6 Data Dictionary Facilities System tables that store metadata System tables that store metadata Users usually can view some of these tables Users usually can view some of these tables Users are restricted from updating them Users are restricted from updating them Some examples in Oracle 10g Some examples in Oracle 10g DBA_TABLES–descriptions of tables DBA_TABLES–descriptions of tables DBA_CONSTRAINTS–description of constraints DBA_CONSTRAINTS–description of constraints DBA_USERS–information about the users of the system DBA_USERS–information about the users of the system Examples in Microsoft SQL Server 2000 Examples in Microsoft SQL Server 2000 SYSCOLUMNS–table and column definitions SYSCOLUMNS–table and column definitions SYSDEPENDS–object dependencies based on foreign keys SYSDEPENDS–object dependencies based on foreign keys SYSPERMISSIONS–access permissions granted to users SYSPERMISSIONS–access permissions granted to users
7
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 7 SQL:1999 and SQL:200 N Enhancements/Extensions User-defined data types (UDT) User-defined data types (UDT) Subclasses of standard types or an object type Subclasses of standard types or an object type Analytical functions (for OLAP) Analytical functions (for OLAP) CEILING, FLOOR, SQRT, RANK, DENSE_RANK CEILING, FLOOR, SQRT, RANK, DENSE_RANK WINDOW–improved numerical analysis capabilities WINDOW–improved numerical analysis capabilities New Data Types New Data Types BIGINT, MULTISET (collection), XML BIGINT, MULTISET (collection), XML CREATE TABLE LIKE–create a new table similar to an existing one CREATE TABLE LIKE–create a new table similar to an existing one MERGE MERGE
8
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 8 Persistent Stored Modules (SQL/PSM) Persistent Stored Modules (SQL/PSM) Capability to create and drop code modules Capability to create and drop code modules New statements: New statements: CASE, IF, LOOP, FOR, WHILE, etc. CASE, IF, LOOP, FOR, WHILE, etc. Makes SQL into a procedural language Makes SQL into a procedural language Oracle has propriety version called PL/SQL, and Microsoft SQL Server has Transact/SQL Oracle has propriety version called PL/SQL, and Microsoft SQL Server has Transact/SQL SQL:1999 and SQL:200 N Enhancements/Extensions (cont.)
9
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 9 Routines and Triggers Routines Routines Program modules that execute on demand Program modules that execute on demand Functions–routines that return values and take input parameters Functions–routines that return values and take input parameters Procedures–routines that do not return values and can take input or output parameters Procedures–routines that do not return values and can take input or output parameters Triggers Triggers Routines that execute in response to a database event (INSERT, UPDATE, or DELETE) Routines that execute in response to a database event (INSERT, UPDATE, or DELETE)
10
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 10 Figure 8-10 Triggers contrasted with stored procedures Procedures are called explicitly Triggers are event-driven Source: adapted from Mullins, 1995.
11
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 11 Figure 8-11 Simplified trigger syntax, SQL:200n Figure 8-12 Create routine syntax, SQL:200n
12
Chapter 8 © 2009 Pearson Education, Inc. Publishing as Prentice Hall 12 Embedded and Dynamic SQL Embedded SQL Embedded SQL Including hard-coded SQL statements in a program written in another language such as C or Java Including hard-coded SQL statements in a program written in another language such as C or Java Dynamic SQL Dynamic SQL Ability for an application program to generate SQL code on the fly, as the application is running Ability for an application program to generate SQL code on the fly, as the application is running
Similar presentations
© 2024 SlidePlayer.com Inc.
All rights reserved.