1 / 13

Object Definition Language and Design Examples

ODL is a design language derived from the OO community, used for relational DB design. Learn ODL's elements, class declarations, relationships, methods, and more through banking and loan examples. Understand how ODL handles cardinality constraints, enum types, and nested relationships.

lbradley
Download Presentation

Object Definition Language and Design Examples

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Object Definition Language • Design language derived from the OO community: • Can be used like E/R as a preliminary design for a relational DB. CORBA ODMG ODL (design OQL (queries Relational design ODL OODMBS input

  2. ODL • Class Declarations • interface < name > {elements = attributes, relationships, methods } • Element Declarations • attribute < type > < name > ; • relationship < rangetype > < name > ; • Method Example • float gpa(in: Student) raises(noGrades) • float = return type. • in: indicates Student argument is read-only. • Other options: out, inout. • noGrades is an exception that can be raised by method gpa.

  3. Banking Example 1 amount Ss# name loandid address type borrower loans customer Belongs-to Customer-of branch branchid location • Keys: ss#, loanid, branchid • Cardinality constraint: each loan belongs to a single branch

  4. Banking Example (II) • interface Customer { attribute string name; attribute integer ss#; attribute Struct Addr {string street, string city, int zip} address; relationship Set<Loans> borrowed inverse Loans::borrower; relationship Set<Branch> has-account-at inverse Branch:patrons;key(ss#) } • Structured types have names and bracketed lists of field-type pairs. • Relationships have inverses. • An element from another class is indicated by < class > :: • Form a set type with Set<type>.

  5. Loans Example (III) • interface loans { attribute real amount; attribute int loanid; attribute Enum loanType {house, car, general} type; relationship Branch belongs-to inverse Branch::loans-granted; relationship Set<Customer> borrower inverse Customer::borrowed; key(loanid) } • Enumerated types have names and bracketed lists of values.

  6. Bank Example (IV) • interface Branch { attribute integer branchid;attribute Struct Customer::Addr location; relationship Set<Loans> loans-granted inverse Loans::belongs-to; relationship Set<Customer> patrons inverse Customer::has-account-at; key(branchid);} • Note reuse of Addr type.

  7. ODL Type System • Basic types: int, real/ float, string, enumerated types, and classes. • Type constructors: Struct for structures and four collection types: Set, Bag, List, and Array.

  8. Limitations on Nesting Relationship class collection Attribute Basic,no class struct collection

  9. ER versus ODL • E/R: arrow pointing to “one. • ODL: don't use a collection type for relationship in the “many" class. • Collection type remains in “one.” • E/R: arrows in both directions. • ODL: omit collection types in both directions • ODL only supports binary relationship. • Convert multi-way relationships to binary and then represent in ODL • create a new connecting entity set to represent the rows in the relationship set. • Problems handling cardinality constraints properly!!

  10. Roles in ODL • No problem; names of relationships handle roles.” interface employee { attribute string name; relationship Set<Employee> manager inverse Employee::worker; relationship Set<Employee> worker inverse Employee::manager } manager works for employee worker

  11. Subclasses in ODL • Subclass = special case = fewer entities/objects = more properties. • Example: Faculty and Staff are subclasses of Employee. Faculty have academic year (9 month salaries) but staff has a full-year (12 month salary).

  12. ODL Subclasses • Follow name of subclass by colon and its superclass. • interface Faculty:Employee { attribute real academic-year-salary;} • Objects of the Faculty class acquire all the attributes and relationships of the Employee class. • Inheritance in ODL and ER model differ in a subtle way • in ODL an object must be member of exactly one class • in ER an object can be member of more than one class

  13. Keys in ODL • Indicate with key(s) following the class name, and a list of attributes forming the key. • Several lists may be used to indicate several alternative keys. • Parentheses group members of a key, and also group key to the declared keys. • Thus, (key(a1; a2; : : : ; an )) = “one key consisting of all n attributes." (key a1; a2; : : : ; an ) =“each ai is a key by itself. • Keys are not necessary for ODL. Object identity and not keys differentiates objects

More Related