1 WG2 N1536 WG3: KOA-046 Temporal Features in SQL standard Krishna Kulkarni, IBM Corporation May 13, 2011.

Slides:



Advertisements
Similar presentations
Manipulating Data Schedule: Timing Topic 60 minutes Lecture
Advertisements

Virtual training week 4 structured query language (SQL)
Time in Databases CSCI 6442 With thanks to Richard Snodgrass, 1985 ACM /85/005/0236.
Introduction to Structured Query Language (SQL)
Fundamentals, Design, and Implementation, 9/e COS 346 Day 11.
Introduction to Structured Query Language (SQL)
SQL components In Oracle. SQL in Oracle SQL is made up of 4 components: –DDL Data Definition Language CREATE, ALTER, DROP, TRUNCATE. Creates / Alters.
Fundamentals, Design, and Implementation, 9/e Chapter 11 Managing Databases with SQL Server 2000.
Fundamentals, Design, and Implementation, 9/e Chapter 6 Introduction to Structured Query Language (SQL)
Introduction to Structured Query Language (SQL)
Database Constraints. Database constraints are restrictions on the contents of the database or on database operations Database constraints provide a way.
Structured Query Language
Oracle Data Definition Language (DDL)
Module 9: Managing Schema Objects. Overview Naming guidelines for identifiers in schema object definitions Storage and structure of schema objects Implementing.
Introduction to SQL Structured Query Language Martin Egerhill.
Advance Computer Programming Java Database Connectivity (JDBC) – In order to connect a Java application to a database, you need to use a JDBC driver. –
PL / SQL P rocedural L anguage / S tructured Q uery L anguage Chapter 7 in Lab Reference.
Introduction to DBMS and SQL Introduction to DBMS and SQL GUIDED BY : MR. YOGESH SAROJ (PGT-CS) MR. YOGESH SAROJ (PGT-CS) Presented By : JAYA XII –COM.
Lecture 2 The Relational Model. Objectives Terminology of relational model. How tables are used to represent data. Connection between mathematical relations.
Chapter 4 The Relational Model.
© 2009 Pearson Education, Inc. Publishing as Prentice Hall 1 Chapter 8 (Part b): Advanced SQL Modern Database Management 9 th Edition Jeffrey A. Hoffer,
Structured Query Language Chapter Three DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 4 th Edition.
AL-MAAREFA COLLEGE FOR SCIENCE AND TECHNOLOGY INFO 232: DATABASE SYSTEMS CHAPTER 7 INTRODUCTION TO STRUCTURED QUERY LANGUAGE (SQL) Instructor Ms. Arwa.
Overview of Standard Query Language (SQL) Saeideh Joodaki Instructor: Dr.Yingshu Li.
Lecture 7 Integrity & Veracity UFCE8K-15-M: Data Management.
SQL (DDL & DML Commands)
DATABASE TRANSACTION. Transaction It is a logical unit of work that must succeed or fail in its entirety. A transaction is an atomic operation which may.
7 1 Chapter 7 Introduction to Structured Query Language (SQL) Database Systems: Design, Implementation, and Management, Seventh Edition, Rob and Coronel.
Chapter 18 Object Database Management Systems. McGraw-Hill/Irwin © 2004 The McGraw-Hill Companies, Inc. All rights reserved. Outline Motivation for object.
Nitin Singh/AAO RTI ALLAHABAD 1 SQL Nitin Singh/AAO RTI ALLAHABAD 2 OBJECTIVES §What is SQL? §Types of SQL commands and their function §Query §Index.
Database Processing: Fundamentals, Design, and Implementation, 9/e by David M. KroenkeChapter 6/1 Copyright © 2004 Please……. No Food Or Drink in the class.
Modern Database Management Chapter 8: Advanced SQL.
6 1 Lecture 8: Introduction to Structured Query Language (SQL) J. S. Chou, P.E., Ph.D.
Database Systems Design, Implementation, and Management Coronel | Morris 11e ©2015 Cengage Learning. All Rights Reserved. May not be scanned, copied or.
Database Systems Design, Implementation, and Management Coronel | Morris 11e ©2015 Cengage Learning. All Rights Reserved. May not be scanned, copied or.
SQL Basics. What is SQL? SQL stands for Structured Query Language. SQL lets you access and manipulate databases.
Database Lab Lecture 1. Database Languages Data definition language ( DDL ) Data definition language –defines data types and the relationships among them.
Objectives Database triggers and syntax
PL/SQLPL/SQL Oracle10g Developer: PL/SQL Programming Chapter 9 Database Triggers.
Topics Related to Attribute Values Objectives of the Lecture : To consider sorting relations by attribute values. To consider Triggers and their use for.
ITEC 3220A Using and Designing Database Systems Instructor: Prof. Z. Yang Course Website: 3220a.htm
PL/SQLPL/SQL Oracle11g: PL/SQL Programming Chapter 9 Database Triggers.
PL/SQLPL/SQL Oracle10g Developer: PL/SQL Programming Chapter 9 Database Triggers.
Retrieving Data in PL/SQL. 2 home back first prev next last What Will I Learn? In this lesson, you will learn to: –Recognize the SQL statements that can.
Chapter 5 : Integrity And Security  Domain Constraints  Referential Integrity  Security  Triggers  Authorization  Authorization in SQL  Views 
Session 1 Module 1: Introduction to Data Integrity
1 CS 430 Database Theory Winter 2005 Lecture 10: Introduction to SQL.
Altering Tables and Constraints Database Systems Objectives Add and modify columns. Add, enable, disable, or remove constraints. Drop a table. Remove.
© 2002 by Prentice Hall 1 Structured Query Language David M. Kroenke Database Concepts 1e Chapter 3 3.
Chapter 18 Object Database Management Systems. Outline Motivation for object database management Object-oriented principles Architectures for object database.
Relational Database Management System(RDBMS) Structured Query Language(SQL)
SQL Triggers, Functions & Stored Procedures Programming Operations.
 CONACT UC:  Magnific training   
LECTURE TWO Introduction to Databases: Data models Relational database concepts Introduction to DDL & DML.
Copyright © 2016 Ramez Elmasri and Shamkant B. Navathe.
1. Advanced SQL Functions Procedural Constructs Triggers.
Views / Session 3/ 1 of 40 Session 3 Module 5: Implementing Views Module 6: Managing Views.
Database Constraints Ashima Wadhwa. Database Constraints Database constraints are restrictions on the contents of the database or on database operations.
The Basics of Data Manipulation
Chapter 6 - Database Implementation and Use
Prepared by : Moshira M. Ali CS490 Coordinator Arab Open University
Module 5: Implementing Data Integrity by Using Constraints
SQL 101.
What Is a View? EMPNO ENAME JOB EMP Table EMPVU10 View
The Basics of Data Manipulation
SQL Fundamentals in Three Hours
Oracle9i Developer: PL/SQL Programming Chapter 8 Database Triggers.
Chapter 8 Advanced SQL.
ISC321 Database Systems I Chapter 4: SQL: Data definition, Constraints, and Basic Queries and Updates Fall 2015 Dr. Abdullah Almutairi.
Prof. Arfaoui. COM390 Chapter 9
Presentation transcript:

1 WG2 N1536 WG3: KOA-046 Temporal Features in SQL standard Krishna Kulkarni, IBM Corporation May 13, 2011

2 Agenda Brief description of the SQL standard List of features in the latest version Application-time period tables System-versioned tables System-versioned application-time period tables Q & A

3 Brief description of the SQL standard ISO/IEC 9075, Database Language SQL is the dominant database language de-jure standard. First published in Revised versions published in 1989, 1992, 1999, 2003, and A new version of SQL expected in late 2011; likely to progress to FDIS stage after the current meetings. Multi-part standard – 9 Parts: 1, 2, 3, 4, 9, 10, 11, 13, and 14; Parts 3, 9, 10, and 13 are currently inactive. Large number of commercial implementations, multi- billion dollar industry. Large number of applications written using SQL.

4 Brief description of the SQL standard (contd.) Divided into 9 parts: Part 1 – Framework (SQL/Framework) Part 2 – Foundation (SQL/Foundation) Part 3 – Call-Level Interface (SQL/CLI) Part 4 – Persistent Stored Modules (SQL/PSM) Part 9 – Management of External Data (SQL/MED) Part 10 – Object Language Bindings (SQL/OLB) Part 11 – Information and Definition Schemas (SQL/Schemata) Part 13 – SQL Routines and Types using the Java Programming Language (SQL/JRT Part 14 – XML-Related Specifications (SQL/XML)

5 Brief description of the SQL standard (contd.) Part 2 – SQL/Foundation: Largest and the most important part SQL General-purpose programming constructs - Data types, expressions, predicates, etc. Data Definition: CREATE/ALTER/DROP of tables, views, constraints, triggers, stored procedures, stored functions, etc. Query constructs: SELECT, joins, etc. Data Manipulation: INSERT, UPDATE, MERGE, DELETE, etc. Access Control: GRANT, REVOKE etc. Transaction Control: COMMIT, ROLLBACK, etc. Connection Management: CONNECT, DISCONNECT, etc. Session Management: SET SESSION statements. Exception Handling: GET DIAGNOSTICS statement

6 Brief description of the SQL standard (contd.) For conformance purpose, SQL is divided into a list of “Features”, grouped under two categories: Mandatory features Optional features To claim conformance, an implementation must conform to all mandatory features. An implementation may conform to any number of optional features. Both are listed in Annex F of each part of the SQL standard. SQL/Foundation:2008 specifies 164 mandatory features and 280 optional features.

7 Agenda Brief description of the SQL standard List of features in the latest version Application-time period tables System-versioned tables System-versioned application-time period tables Q & A

8 List of features in the latest version New version of SQL standard has completed the FCD ballot; expected to progress FDIS ballot in a couple of months. A total 34 new features have been added to SQL/Foundation– all in the optional category. This brings the list of optional features in SQL/Foundation to 314: F054 TIMESTAMP in DATE type precedence list F202 TRUNCATE TABLE: identity column restart option F314 MERGE Statement with DELETE branch F383 Set column not null clause F384 Drop identity property clause

9 List of features in the latest version (contd.) F385 Drop column generation expression clause F386 Set identity column generation clause F492 Optional table constraint enforcement F860 Dynamic in F861 Top-level in F862 in subqueries F863 Nested in F864 Top-level in views F865 Dynamic in F866 FETCH FIRST clause: PERCENT option F867 FETCH FIRST clause: WITH TIES option

10 List of features in the latest version (contd.) S401 Distinct types based on array types S402 Distinct types based on distinct types S403 ARRAY_MAX_CARDINALITY S404 TRIM_ARRAY T177 Sequence generator support: simple restart option T178 Identity columns: simple restart option T180 System-versioned tables T181 Application-time period tables T495 Combined data change and retrieval T521 Named arguments in CALL statement T522 Default values for IN parameters of SQL-invoked procedures

11 List of features in the latest version (contd.) T614 NTILE function T615 LEAD and LAG functions T616 NULL treatment option for LEAD and LAG functions T617 FIRST_VALUE and LAST_VALUE functions T618 NTH_VALUE function T619 Nested window functions T620 WINDOW clause: GROUPS option

12 Agenda Brief description of the SQL standard List of features in the latest version Application-time period tables System-versioned tables System-versioned application-time period tables Q & A

13 Feature T181 – Application-time period tables Application-time period tables are tables that contain a PERIOD clause (newly-introduced) with an user-defined period name. Currently restricted to temporal periods only; may be relaxed in the future. Application-time period tables must contain two additional columns, one to store the start time of a period associated with the row and one to store the end time of the period. Values of both start and end columns are set by the users. Additional syntax is provided for users to specify primary key/unique constraints that ensure no two rows with the same key value have overlapping periods.

14 Feature T181 – Application-time period tables (contd.) Additional syntax is provided for users to specify referential constraints that ensure the period of every child row is completely contained in the period of exactly one parent row or in the combined period of two or more consecutive parent rows. Queries, inserts, updates and deletes on application-time period tables behave exactly like queries, inserts, updates and deletes on regular tables. Additional syntax is provided on UPDATE and DELETE statements for partial period updates and deletes.

15 Creating an application-time period table CREATE TABLE employees (emp_name VARCHAR(50) NOT NULL PRIMARY KEY, dept_id VARCHAR(10), start_date DATE NOT NULL, end_date DATE NOT NULL, PERIOD FOR emp_period (start_date, end_date), PRIMARY KEY (emp_name, emp_period WITHOUT OVERLAPS), FOREIGN KEY (dept_id, PERIOD emp_period) REFERENCES departments (dept_id, PERIOD dept_period)); Notes: PERIOD clause automatically enforces the constraint (end_date > start_date). The name of the period can be any user-defined name. The period is considered to start on the start_date value and end on the value just prior to end_date value. This corresponds to the (closed, open) model of periods.

16 Inserting rows into an application-time period table When a row is inserted into an application-time period table, user provides the start and end time of the period for each row. User-supplied time values can be either in the past, current, or in the future.

17 Business_time values are set by user. Inserting rows into an application-time period table (contd.) emp_namedept_idstart_dateend_date JohnJ1311/15/199511/15/1996 TracyK2501/01/199611/15/1997 The following INSERT is executed in some transaction: INSERT INTO employees (emp_name, dept_id, start_date, end_date) VALUES (‘John’, ’J13’, DATE ‘ ’, DATE ‘ ’), (‘Tracy’,’K25’, DATE ‘ ’, DATE ‘ ) Business_time period (closed, open)

18 Inserting rows into an application-time period table (contd.) emp_namedept_idstart_dateend_date JohnJ1311/15/199511/15/1996 TracyK2501/01/199611/15/1997 Given the following content The following INSERT will succeed INSERT INTO employees (emp_name, dept_id, start_date, end_date) VALUES (‘John’, ’J13’, DATE ‘ ’, DATE ‘ ’’), (‘John’,’J12’, DATE ‘ ’, DATE ‘ ’) While the following INSERT will not, because of the inclusion of emp_period WITHOUT OVERLAPS in the primary key definition: INSERT INTO employees (emp_name, dept_id, start_date, end_date) VALUES (‘John’, ’J13’, DATE ‘ ’, DATE ‘ ’’)

19 Updating rows in an application-time period table All rows can be potentially updated. Users are allowed to update the start and end columns of the period associated with each row. When a row from an application-time period table is updated using the regular UPDATE statements, the regular semantics apply. Additional syntax is provided for UPDATE statements to specify the time period during which the update applies. Only those rows that lie within the specified period are impacted. May lead to row splits, i.e., update of a row may cause insertion of up to two rows to preserve the information for the periods that lie outside the specified period. Users are not allowed to update the start and end columns of the period associated with each row under this option.

20 No changes to the Business_time values. Updating rows in an application-time period table (contd.) emp_namedept_idstart_dateend_date JohnJ1511/15/199511/15/1996 TracyK2501/01/199611/15/1997 The following UPDATE is executed in some transaction: UPDATE employees SET dept_id = ‘J15’’ WHERE emp_name = ‘John’

21 Automatic row splitting – 1 update and 2 inserts. Updating rows in an application-time period table (contd.) The following UPDATE is executed in some transaction: UPDATE employees FOR PORTION OF emp_period FROM DATE ‘ ’ TO DATE ‘ ’ SET dept_id = ‘M12’’ WHERE emp_name = ‘John’ emp_namedept_idstart_dateend_date JohnJ1511/15/199503/01/1996 JohnM1203/01/199607/01/1996 JohnJ1507/01/199611/15/1996 TracyK2501/01/199611/15/1997

22 Deleting rows from an application-time period table All rows can be potentially deleted. When a row from an application-time period table is deleted using the regular DELETE statements, the regular semantics apply. Additional syntax is provided for DELETE statements to specify the time period during which the delete applies. Only those rows that lie within the specified period are impacted. May lead to row splits, i.e., delete of a row may cause insertion of up to two rows to preserve the information for the periods that lie outside the specified period.

23 Automatic row splitting – 1 delete and 2 inserts Deleting rows from an application-time period table (contd.) The following DELETE is executed in some transaction: DELETE FROM employees FOR PORTION OF emp_period FROM DATE ‘ ’ TO DATE ‘ ’ WHERE emp_name = ‘John’ emp_namedept_idstart_dateend_date JohnJ1511/15/199503/01/1996 JohnM1203/01/199607/01/1996 JohnJ1507/01/199608/01/1996 JohnJ1509/01/199611/15/1996 TracyK2501/01/199611/15/1997

24 All rows pertaining to John are deleted. Deleting rows from an application-time period table (contd.) emp_namedept_idstart_dateend_date TracyK2501/01/199611/15/1997 The following DELETE is executed in some transaction: DELETE FROM employees WHERE EmpName = ‘John’

25 Querying an application-time period table Existing syntax for querying regular tables is applicable to application-time period tables also.

26 Querying an application-time period table (contd.) 1.Which department was John in on Dec. 1, 1997? SELECT dept_id FROM employees WHERE emp_name = ‘John’ AND start_date DATE ‘ ’ ; employees J13 emp_namedept_idstart_datesystem_end JohnM JohnJ TracyK2501/01/

27 Querying an application-time period table 1.Which department is John in currently? SELECT dept_id FROM employees WHERE emp_name = ‘John’ AND start_date CURRENT_DATE; employees M24 emp_namedept_idstart_datesystem_end JohnM JohnJ TracyK2501/01/

28 Querying an application-time period table 1.How many departments has John worked in since Jan. 1, 1996? SELECT count(distinct dept_id) FROM employees WHERE emp_name = ‘John’ start_date DATE ‘ ’; employees 2 emp_namedept_idstart_datesystem_end JohnM JohnJ TracyK2501/01/

29 Benefits of application-time period tables Most business data is time sensitive, i.e., need to track the time period during when a data item is deemed valid or effective from the business point of view. Database systems today offer no support for: Associating user-maintained time periods with rows. Enforcing constraints such as “an employee can be in only one department in any given period”. Updating/deleting a row for a part of its validity period. Currently, applications take on the responsibility for managing such requirements. Major Issues: Complexity of code Poor performance

30 Benefits of application-time period tables Use of application-time period tables provides: Significant simplification of application code Significant improvement in performance Transparent to legacy applications

31 Agenda Brief description of the SQL standard List of features in the latest version Application-time period tables System-versioned tables System-versioned application-time period tables Q & A

32 Feature T180 - System-versioned tables System-versioned tables are tables that contain a PERIOD clause with a pre-defined period name (SYSTEM_TIME) and specify WITH SYSTEM VERSIONING. System-versioned tables must contain two additional columns, one to store the start time of the SYSTEM_TIME period and one to store the end time of the SYSTEM_TIME period. Values of both start and end columns are set by the system. Users are not allowed to supply values for these columns. Unlike regular tables, system-versioned tables preserve the old versions of rows as the table is updated. Rows whose periods intersect the current time are called current system rows. All others are called historical system rows. Only current system rows can be updated or deleted. All constraints are enforced on current system rows only.

33 Creating a system-versioned table CREATE TABLE employees (emp_name VARCHAR(50) NOT NULL, dept_id VARCHAR(10), system_start TIMESTAMP(6) GENERATED ALWAYS AS ROW START, system_end TIMESTAMP(6) GENERATED ALWAYS AS ROW END, PERIOD FOR SYSTEM_TIME (system_start, system_end), PRIMARY KEY (emp_name), FOREIGN KEY (dept_id) REFERENCES departments (dept_id); ) WITH SYSTEM VERSIONING; Notes: PERIOD clause automatically enforces the constraint (system_end > system_start). The name of the period must be SYSTEM_TIME. The period is considered to start on the system_start value and end on the value just prior to system_end value. This corresponds to the (closed, open) model of periods.

34 Inserting rows into a system-versioned table When a row is inserted into a system-versioned table, the SQL-implementation sets the start time to the transaction time and the end time to the largest timestamp value. All rows inserted in a transaction will get the same values for the start and end columns.

35 System_start and system_end values are set by DBMS. Inserting rows into a system-versioned table (contd.) emp_namedept_idsystem_startsystem_end JohnJ TracyK The following INSERT is executed at timestamp 11/15/1995 ….: INSERT INTO emp (emp_name, dept_id) VALUES (‘John’, ’J13’), (‘Tracy’,’K25’) Notes: Ony date components of system_start and system_end values are shown for the purpose of simplifying display. employees

36 Updating rows in a system-versioned table When a row from a system-versioned table is updated, the SQL-implementation inserts the “old” version of the row into the table before updating the row. SQL-implementation sets the end time of the old row and the start time of the updated row to the transaction time. Users are not allowed to update the start and end columns.

37 Updating rows in a system-versioned table (contd.) emp_namedept_idsystem_startsystem_end JohnM JohnJ TracyK The following UPDATE is executed at timestamp 1/31/1998 …: UPDATE emp SET dept_id = ‘M24’’ WHERE emp_name = ‘John’ employees

38 Deleting rows from a system-versioned table When a row from a system-versioned table is deleted, the SQL-implementation does not actually delete the row; it simply sets its end time to the transaction time.

39 Deleting rows from a system-versioned table (contd.) The following DELETE is executed on 3/31/2000: DELETE FROM emp WHERE emp_name = ‘Tracy’ emp_namedept_idsystem_startsystem_end JohnM JohnJ TracyK employees

40 Querying system-versioned tables Existing syntax for querying regular tables is applicable to system-versioned tables also. Additional syntax is provided for expressing queries involving system-versioned tables in a more succinct manner: FOR SYSTEM_TIME AS OF FOR SYSTEM_TIME BETWEEN AND FOR SYSTEM_TIME FROM TO

41 Querying system-versioned tables 1.Which department was John in on Dec. 1, 1997? SELECT Dept FROM employees FOR SYSTEM_TIME AS OF DATE ‘ ’ WHERE emp_name = ‘John’ employees J13 emp_namedept_idsystem_startsystem_end JohnM JohnJ TracyK

42 Querying system-versioned tables 1.Which department is John in currently? SELECT Dept FROM employees WHERE emp_name = ‘John’ employees M24 emp_namedept_idsystem_startsystem_end JohnM JohnJ TracyK Note: If AS OF clause is not specified, only current system rows are returned, i.e., FOR SYSTEM_TIME AS OF CURRENT_TIMESTAMP is the default.

43 Querying system-versioned tables 1.How many departments has John worked in since Jan. 1, 1996? SELECT count(distinct dept_id) FROM employees FOR SYSTEM_TIME BETWEEN DATE ‘ ’ AND CURRENT_DATE WHERE emp_name = ‘John’ employees 2 emp_namedept_idsystem_startsystem_end JohnM JohnJ TracyK

44 Benefits of system-versioned tables Today’s database systems focus mainly on managing current data; they provide almost no support for managing historical data. Some applications have an inherent need for preserving old data. Examples: job histories, salary histories, account histories, etc. Regulatory and compliance laws require keeping old data around for certain length of time. Currently, applications take on the responsibility for preserving old data. Major Issues: Complexity of code Poor performance

45 Benefits of system-versioned tables (contd.) Use of system-versioned tables provides: Significant simplification of application code Significant improvement in performance Transparent to legacy applications

46 Agenda Brief description of the SQL standard List of features in the latest version Application-time period tables System-versioned tables System-versioned application-time period tables Q & A

47 System-versioned application-time period tables A table that is both an application-time period table and a system-versioned table. Such a table supports features of both application-time period tables and system-versioned tables.

48 Creating a system-versioned application-time period table CREATE TABLE employees (emp_name VARCHAR(50) NOT NULL PRIMARY KEY, dept_id VARCHAR(10), start_date DATE NOT NULL, end_date DATE NOT NULL, system_start TIMESTAMP(6) GENERATED ALWAYS AS ROW START, System_end TIMESTAMP(6) GENERATED ALWAYS AS ROW END, PERIOD FOR emp_period (start_date, end_date), PERIOD FOR SYSTEM_TIME (system_start, system_end), PRIMARY KEY (emp_name, emp_period WITHOUT OVERLAPS), FOREIGN KEY (dept_id, PERIOD emp_period) REFERENCES departments (dept_id, PERIOD dept_period) ) WITH SYSTEM VERSIONING;

49 system_start and system_end values are set by the system. Insert emp_namedept_idstart_dateend_datesystem_startsystem_end JohnJ1311/15/199512/31/999911/01/199512/31/9999 TracyK2511/15/199512/31/999911/01/199512/31/9999 On 11/01/1995, employees table was updated to show that John and Tracy will be joining the departments J13 & K25, respectively, starting from 11/15/1995. INSERT INTO employees (emp_name, dept_id, start_date, end_date) VALUES (‘John’, ’J13’, DATE ‘ ’, DATE ‘ ’), (‘Tracy’,’K25’, DATE ‘ ’, DATE ‘ ) Note: DATE type is used in examples instead of TIMESTAMP type to simplify display. employees

50 Update emp_namedept_idstart_dateend_datesystem_startsystem_end JohnJ1511/15/199512/31/999911/10/199512/31/9999 JohnJ1311/15/199512/31/999911/01/199511/10/1995 TracyK2511/15/199512/31/999911/01/199512/31/9999 On 11/10/1995, it was discovered that John was assigned to the wrong department. It was changed to department J15 on that day. UPDATE employees SET dept_id = ‘J15’’ WHERE emp_name = ‘John’ employees

51 Partial period update Emp_namedept_idetart_dateend_datesystem_startsystem_end JohnJ1507/01/199812/31/999912/15/199712/31/9999 JohnM1201/01/199807/01/199812/15/199712/31/9999 JohnJ1511/15/199501/01/199812/15/199712/31/9999 JohnJ1511/15/199512/31/999911/10/199512/15/1997 JohnJ1311/15/199512/31/999911/01/199511/10/1995 TracyK2511/15/199512/31/999911/01/199512/31/9999 On 12/15/1997, John is loaned to Dept M12 starting from 1/1/1998 to 7/1/1998. UPDATE employees FOR PORTION OF emp_period FROM DATE ‘ ’ TO DATE ‘ ’ SET dept_id = ‘M12’’ WHERE emp_name = ‘John’ employees

52 Partial period delete emp_namedept_idstart_dateend_datesystem_startsystem_end JohnJ1501/01/200012/31/999912/15/199812/31/9999 JohnJ1507/01/199801/01/199912/15/199812/31/9999 JohnM1201/01/199807/01/199812/15/199712/31/9999 JohnJ1511/15/199501/01/199812/15/199712/31/9999 JohnJ1507/01/199812/31/999912/15/199712/15/1998 JohnJ1511/15/199512/31/999911/10/199512/15/1997 JohnJ1311/15/199512/31/999911/01/199511/10/1995 TracyK2511/15/199512/31/999911/01/199512/31/9999 On 12/15/1998, John is approved for a leave of absence from 1/1/1999 to 1/1/2000. DELETE FROM employees FOR PORTION OF emp_period FROM DATE ‘ ’ TO DATE ‘ ’ WHERE emp_name = ‘John’ employees

53 Delete emp_namedept_idstart_dateend_datesystem_startsystem_end JohnJ1501/01/200012/31/999912/15/199806/01/2000 JohnJ1507/01/199801/01/199912/15/199806/01/2000 JohnM1201/01/199807/01/199812/15/199706/01/2000 JohnJ1511/15/199501/01/199812/15/199706/01/2000 JohnJ1507/01/199812/31/199912/15/199712/15/1998 JohnJ1511/15/199512/31/999911/10/199512/15/1997 JohnJ1311/15/199512/31/999911/01/199511/10/1995 TracyK2511/15/199512/31/999911/01/199512/31/9999 On 6/1/2000, John resigns from the company. DELETE FROM employees WHERE emp_name = ‘John’ employees

54 Agenda Brief description of the SQL standard List of features in the latest version System-versioned tables Application-time period tables System-versioned application-time period tables Q &A