1 Object-Oriented Database Languages Object Description Language Object Query Language.

Slides:



Advertisements
Similar presentations
Union, Intersection, Difference (subquery) UNION (subquery) produces the union of the two relations. Similarly for INTERSECT, EXCEPT = intersection and.
Advertisements

SQL Group Members: Shijun Shen Xia Tang Sixin Qiang.
1 Introduction to SQL Select-From-Where Statements Multirelation Queries Subqueries.
SQL Queries Principal form: SELECT desired attributes FROM tuple variables –– range over relations WHERE condition about tuple variables; Running example.
Winter 2002Arthur Keller – CS 1806–1 Schedule Today: Jan. 22 (T) u SQL Queries. u Read Sections Assignment 2 due. Jan. 24 (TH) u Subqueries, Grouping.
Dale Roberts 1 Department of Computer and Information Science, School of Science, IUPUI Dale Roberts, Lecturer Computer Science, IUPUI
SQL CSET 3300.
CS411 Database Systems Kazuhiro Minami 06: SQL. Join Expressions.
1 Database Systems Relations as Bags Grouping and Aggregation Database Modification.
1 Introduction to SQL Multirelation Queries Subqueries Slides are reused by the approval of Jeffrey Ullman’s.
Chapter 4 Notes. Entity-Relationship Model E/R Diagrams Weak Entity Sets Converting E/R Diagrams to Relations.
Fall 2001Arthur Keller – CS 18016–1 Schedule Nov. 20 (T) More OQL. u Read Sections Assignment 7 due (late ones by ). Nov. 22 (TH) Thanksgiving.
Winter 2002Arthur Keller – CS 18015–1 Schedule Today: Feb. 28 (TH) u Datalog and SQL Recursion, ODL. u Read Sections , Project Part 6.
Object-Orientation in Query Languages By: Toan Nguyen Class: CS 157A.
Fall 2001Arthur Keller – CS 18015–1 Schedule Nov. 15 (TH) Object Queries (OQL). u Read Sections 9.1. Project Part 6 due on Sunday night. Nov. 20 (T) More.
1 More SQL Defining a Database Schema Views. 2 Defining a Database Schema uA database schema comprises declarations for the relations (“tables”) of the.
Winter 2002Arthur Keller – CS 18016–1 Schedule Today: Mar. 5 (T) u More ODL, OQL. u Read Sections 9.1. Assignment 7 due. Mar. 7 (TH) u More OQL. u Read.
1 Unified Modeling Language Classes Associations Aggregations.
CPSC-608 Database Systems Fall 2011 Instructor: Jianer Chen Office: HRBB 315C Phone: Notes #3.
1 Other High-Level Design Languages Unified Modeling Language Object Description Language.
Programs with SQL Host language + Embedded SQL Preprocessor Host Language + function calls Host language compiler Host language program Preprocessor Host.
1 SQL/PSM Procedures Stored in the Database General-Purpose Programming.
Winter 2002Arthur Keller – CS 1807–1 Schedule Today: Jan. 24 (TH) u Subqueries, Grouping and Aggregation. u Read Sections Project Part 2 due.
1 Entity-Relationship Model Diagrams Class hierarchies Weak entity sets.
1 More SQL Extended Relational Algebra Outerjoins, Grouping/Aggregation Insert/Delete/Update.
1 Announcements Research Paper due Monday November 22.
Databases Illuminated Chapter 7 The Object-Oriented Model.
Object and object-relational databases 1. Object databases vs. Object-relational databases Object databases Stores complex objects – Data + functions.
Chapter 6 Notes. 6.1 Simple Queries in SQL SQL is not usually used as a stand-alone language In practice there are hosting programs in a high-level language.
SCUHolliday6–1 Schedule Today: u SQL Queries. u Read Sections Next time u Subqueries, Grouping and Aggregation. u Read Sections And then.
Database Management COP4540, SCS, FIU Relational Model Chapter 7.
1 Object-Oriented Database Languages Object Description Language Object Query Language.
Database Management COP4540, SCS, FIU Database Modeling A Introduction to object definition language (ODL)
Chapter 21 C OQL Copyright © 2004 Pearson Education, Inc.
Object Definition Language
1 Real SQL Programming Persistent Stored Modules (PSM) PL/SQL Embedded SQL.
Entity-Relationship Model
Database Design Why do we need it? – Agree on structure of the database before deciding on a particular implementation. Consider issues such as: –What.
Winter 2006Keller Cushing Ullman17–1 Subqueries Used mainly in FROM clauses and with quantifiers EXISTS and FORALL. Example: Subquery in FROM Find the.
Databases 1 Second lecture.
1 CSCE Database Systems Anxiao (Andrew) Jiang The Database Language SQL.
© D. Wong Security and User Authorization in SQL 8.7 pp. 410  Authorization ID = user name  Special authorization ID: PUBLIC  Privileges for:
1 Introduction to SQL Database Systems. 2 Why SQL? SQL is a very-high-level language, in which the programmer is able to avoid specifying a lot of data-manipulation.
Himanshu GuptaCSE 532-SQL-1 SQL. Himanshu GuptaCSE 532-SQL-2 Why SQL? SQL is a very-high-level language, in which the programmer is able to avoid specifying.
SCUHolliday - coen 1787–1 Schedule Today: u Subqueries, Grouping and Aggregation. u Read Sections Next u Modifications, Schemas, Views. u Read.
More SQL (and Relational Algebra). More SQL Extended Relational Algebra Outerjoins, Grouping/Aggregation Insert/Delete/Update.
1 Unified Modeling Language. 2 UML  UML is designed to model software, but has been adapted as a database modeling language. – No multiway relationships.
1 Database Design: DBS CB, 2 nd Edition Logical Database Model: Entity Relationship Model & Object Description Language & Unified Modeling Language Ch.
1 Introduction to Database Systems, CS420 SQL JOIN, Aggregate, Grouping, HAVING and DML Clauses.
1. 2 Standards group: ODMG = Object Data Management Group. ODL = Object Description Language, like CREATE TABLE part of SQL. OQL = Object Query Language,
Schedule Today: Jan. 28 (Mon) Jan. 30 (Wed) Next Week Assignments !!
Slides are reused by the approval of Jeffrey Ullman’s
CPSC-310 Database Systems
Outerjoins, Grouping/Aggregation Insert/Delete/Update
Database Design Why do we need it? Consider issues such as:
Databases : More about SQL
CPSC-310 Database Systems
Schedule Today: Next After that Subqueries, Grouping and Aggregation.
CPSC-608 Database Systems
CPSC-310 Database Systems
IST 210: Organization of Data
CPSC-310 Database Systems
Object Definition Language
CPSC-608 Database Systems
More SQL Extended Relational Algebra Outerjoins, Grouping/Aggregation
CSC Database Management Systems
Object-Oriented DBMS’s
Instructor: Zhe He Department of Computer Science
Select-From-Where Statements Multirelation Queries Subqueries
Presentation transcript:

1 Object-Oriented Database Languages Object Description Language Object Query Language

2 Object-Oriented DBMS’s uStandards group: ODMG = Object Data Management Group. uODL = Object Description Language, like CREATE TABLE part of SQL. uOQL = Object Query Language, tries to imitate SQL in an OO framework.

3 Framework --- (1) uODMG imagines OO-DBMS vendors implementing an OO language like C++ with extensions (OQL) that allow the programmer to transfer data between the database and “host language” seamlessly.

4 Framework --- (2) uODL is used to define persistent classes, those whose objects may be stored permanently in the database. wODL classes look like Entity sets with binary relationships, plus methods. wODL class definitions are part of the extended, OO host language.

5 ODL Overview uA class declaration includes: 1.A name for the class. 2.Optional key declaration(s). 3.Extent declaration = name for the set of currently existing objects of the class. 4.Element declarations. An element is either an attribute, a relationship, or a method.

6 Class Definitions class { <list of element declarations, separated by semicolons> }

7 Attribute and Relationship Declarations uAttributes are (usually) elements with a type that does not involve classes. attribute ; uRelationships connect an object to one or more other objects of one class. relationship inverse ;

8 Inverse Relationships uSuppose class C has a relationship R to class D. uThen class D must have some relationship S to class C. uR and S must be true inverses. wIf object d is related to object c by R, then c must be related to d by S.

9 Example: Attributes and Relationships class Bar { attribute string name; attribute string addr; relationship Set serves inverse Beer::servedAt; } class Beer { attribute string name; attribute string manf; relationship Set servedAt inverse Bar::serves; } The type of relationship serves is a set of Beer objects. The :: operator connects a name on the right to the context containing that name, on the left.

10 Types of Relationships uThe type of a relationship is either 1.A class, like Bar. If so, an object with this relationship can be connected to only one Bar object. 2.Set : the object is connected to a set of Bar objects. 3.Bag, List, Array : the object is connected to a bag, list, or array of Bar objects.

11 Multiplicity of Relationships uAll ODL relationships are binary. uMany-many relationships have Set for the type of the relationship and its inverse. uMany-one relationships have Set in the relationship of the “one” and just the class for the relationship of the “many.” uOne-one relationships have classes as the type in both directions.

12 Example: Multiplicity class Drinker { … relationship Set likes inverse Beer::fans; relationship Beer favBeer inverse Beer::superfans; } class Beer { … relationship Set fans inverse Drinker::likes; relationship Set superfans inverse Drinker::favBeer; } Many-many uses Set in both directions. Many-one uses Set only with the “one.”

13 Another Multiplicity Example class Drinker { attribute … ; relationship Drinker husband inverse wife; relationship Drinker wife inverse husband; relationship Set buddies inverse buddies; } husband and wife are one-one and inverses of each other. buddies is many-many and its own inverse. Note no :: needed if the inverse is in the same class.

14 Coping With Multiway Relationships uODL does not support 3-way or higher relationships. uWe may simulate multiway relationships by a “connecting” class, whose objects represent tuples of objects we would like to connect by the multiway relationship.

15 Connecting Classes uSuppose we want to connect classes X, Y, and Z by a relationship R. uDevise a class C, whose objects represent a triple of objects (x, y, z) from classes X, Y, and Z, respectively. uWe need three many-one relationships from (x, y, z) to each of x, y, and z.

16 Example: Connecting Class uSuppose we have Bar and Beer classes, and we want to represent the price at which each Bar sells each beer. wA many-many relationship between Bar and Beer cannot have a price attribute as it did in the E/R model. uOne solution: create class Price and a connecting class BBP to represent a related bar, beer, and price.

17 Example --- Continued uSince Price objects are just numbers, a better solution is to: 1.Give BBP objects an attribute price. 2.Use two many-one relationships between a BBP object and the Bar and Beer objects it represents.

18 Example, Concluded uHere is the definition of BBP: class BBP { attribute price:real; relationship Bar theBar inverse Bar::toBBP; relationship Beer theBeer inverse Beer::toBBP; } uBar and Beer must be modified to include relationships, both called toBBP, and both of type Set.

19 Structs and Enums uAttributes can have a structure (as in C) or be an enumeration. uDeclare with attribute [Struct or Enum] <name of struct or enum> { } ; uDetails are field names and types for a Struct, a list of constants for an Enum.

20 Example: Struct and Enum class Bar { attribute string name; attribute Struct Addr {string street, string city, int zip} address; attribute Enum Lic { FULL, BEER, NONE } license; relationship … } Names for the structure and enumeration names of the attributes

21 Method Declarations uA class definition may include declarations of methods for the class. uInformation consists of: 1.Return type, if any. 2.Method name. 3.Argument modes and types (no names). wModes are in, out, and inout. 4.Any exceptions the method may raise.

22 Example: Methods real gpa(in string)raises(noGrades); 1.The method gpa returns a real number (presumably a student’s GPA). 2.gpa takes one argument, a string (presumably the name of the student) and does not modify its argument. 3.gpa may raise the exception noGrades.

23 The ODL Type System uBasic types: int, real/float, string, enumerated types, and classes. uType constructors: wStruct for structures. wCollection types : Set, Bag, List, Array, and Dictionary ( = mapping from a domain type to a range type). uRelationship types can only be a class or a single collection type applied to a class.

24 ODL Subclasses uUsual object-oriented subclasses. uIndicate superclass with a colon and its name. uSubclass lists only the properties unique to it. wAlso inherits its superclass’ properties.

25 Example: Subclasses uAles are a subclass of beers: class Ale:Beer { attribute string color; }

26 ODL Keys uYou can declare any number of keys for a class. uAfter the class name, add: (key ) uA key consisting of more than one attribute needs additional parentheses around those attributes.

27 Example: Keys class Beer (key name) { … uname is the key for beers. class Course (key (dept,number),(room, hours)){ udept and number form one key; so do room and hours.

28 Extents uFor each class there is an extent, the set of existing objects of that class. wThink of the extent as the one relation with that class as its schema. uIndicate the extent after the class name, along with keys, as: (extent … )

29 Example: Extents class Beer (extent Beers key name) { … } uConventionally, we’ll use singular for class names, plural for the corresponding extent.

30 OQL uOQL is the object-oriented query standard. uIt uses ODL as its schema definition language. uTypes in OQL are like ODL’s. uSet(Struct) and Bag(Struct) play the role of relations.

31 Path Expressions uLet x be an object of class C. 1.If a is an attribute of C, then x.a is the value of that attribute. 2.If r is a relationship of C, then x.r is the value to which x is connected by r. wCould be an object or a set of objects, depending on the type of r. 3.If m is a method of C, then x.m (…) is the result of applying m to x.

32 Running Example class Sell (extent Sells) { attribute real price; relationship Bar bar inverse Bar::beersSold; relationship Beer beer inverse Beers::soldBy; } class Bar (extent Bars) { attribute string name; attribute string addr; relationship Set beersSold inverse Sell::bar; }

33 Running Example --- Concluded class Beer (extent Beers) { attribute string name; attribute string manf; relationship Set soldBy inverse Sell::beer; }

34 Example: Path Expressions uLet s be a variable of type Sell, i.e., a bar-beer-price object. 1.s.price = the price in object s. 2.s.bar.addr = the address of the bar we reach by following the bar relationship in s. wNote the cascade of dots is OK here, because s.bar is an object, not a collection of objects.

35 Example: Illegal Use of Dot uWe cannot apply the dot with a collection on the left --- only with a single object. uExample (illegal), with b a Bar object: b.beersSold.price This expression is a set of Sell objects. It does not have a price.

36 OQL Select-From-Where uWe may compute relation-like collections by an OQL statement: SELECT FROM <list of collections and names for typical members> WHERE

37 FROM Clauses uEach term of the FROM clause is: uA collection can be: 1.The extent of some class. 2.An expression that evaluates to a collection, e.g., certain path expressions like b.beersSold.

38 Example uGet the menu at Joe’s Bar. SELECT s.beer.name, s.price FROM Sells s WHERE s.bar.name = “Joe’s Bar” Sells is the extent representing all Sell objects; s represents each Sell object, in turn. Legal expressions. s.beer is a beer object and s.bar is a Bar object. Notice OQL uses double-quotes.

39 Another Example uThis query also gets Joe’s menu: SELECT s.beer.name, s.price FROM Bars b, b.beersSold s WHERE b.name = “Joe’s Bar” b.beersSold is a set of Sell objects, and s is now a typical sell object that involves Joe’s Bar.

40 Trick For Using Path Expressions uIf a path expression denotes an object, you can extend it with another dot and a property of that object. wExample: s, s.bar, s.bar.name. uIf a path expression denotes a collection of objects, you cannot extend it, but you can use it in the FROM clause. wExample: b.beersSold.

41 The Result Type uAs a default, the type of the result of select-from-where is a Bag of Structs. wStruct has one field for each term in the SELECT clause. Its name and type are taken from the last name in the path expression. uIf SELECT has only one term, technically the result is a one-field struct. wBut a one-field struct is identified with the element itself.

42 Example: Result Type SELECT s.beer.name, s.price FROM Bars b, b.beersSold s WHERE b.name = “Joe’s Bar” uHas type: Bag(Struct(name: string, price: real))

43 Renaming Fields uTo change a field name, precede that term by the name and a colon. uExample: SELECT beer: s.beer.name, s.price FROM Bars b, b.beersSold s WHERE b.name = “Joe’s Bar” uResult type is Bag(Struct(beer: string, price: real)).

44 Producing a Set of Structs uAdd DISTINCT after SELECT to make the result type a set, and eliminate duplicates. uExample: SELECT DISTINCT s.beer.name, s.price FROM Bars b, b.beersSold s WHERE b.name = “Joe’s Bar” uResult type is Set(Struct(name: string, price: string))

45 Subqueries uA select-from-where expression can be surrounded by parentheses and used as a subquery in several ways, such as: 1.In a FROM clause, as a collection. 2.In EXISTS and FOR ALL expressions.

46 Example: Subquery in FROM uFind the manufacturers of beers sold at Joe’s: SELECT DISTINCT b.manf FROM ( SELECT s.beer FROM Sells s WHERE s.bar.name = “Joe’s Bar” ) b Bag of Beer objects for the beers sold by Joe Technically a one-field struct containing a Beer object, but identified with that object itself.

47 Quantifiers uTwo boolean-valued expressions for use in WHERE clauses: FOR ALL x IN : EXISTS x IN : uTrue if and only if all members (resp. at least one member) of the collection satisfy the condition.

48 Example: EXISTS uFind all names of bars that sell at least one beer for more than $5. SELECT b.name FROM Bars b WHERE EXISTS s IN b.beersSold : s.price > 5.00 At least one Sell object for bar b has a price above $5.

49 Another Quantifier Example uFind the names of all bars such that the only beers they sell for more than $5 are manufactured by Pete’s. SELECT b.name FROM Bars b WHERE FOR ALL be IN ( SELECT s.beer FROM b.beersSold s WHERE s.price > 5.00 ) : be.manf = “Pete’s” Bag of Beer objects (inside structs) for all beers sold by bar b for more than $5. One-field structs are unwrapped automatically, so be may be thought of as a Beer object.

50 Simple Coercions uAs we saw, a one-field struct is automatically converted to the value of the one field. wStruct(f : x) coerces to x. uA collection of one element can be coerced to that element, but we need the operator ELEMENT. wE.g., ELEMENT(Bag(x )) = x.

51 Aggregations uAVG, SUM, MIN, MAX, and COUNT apply to any collection where they make sense. uExample: Find and assign to x the average price of beer at Joe’s: x = AVG( SELECT s.price FROM Sells s WHERE s.bar.name = “Joe’s Bar” ); Bag of structs with the prices for the beers Joe sells.