CSC/ECE 517 Fall 2007/wiki2 2 aa: Difference between revisions

From Expertiza_Wiki
Jump to navigation Jump to search
Line 3: Line 3:
=Introduction=
=Introduction=


Object-oriented programming uses '''Object''' to manage data. Objects have identity, state, and behavior, which means Object is focus on identity and behavior of the things in real world. However '''relational database''' is focus on information. It is a collection of relation variables between the ''attributes'' of ''tables'', it describes the complete state of an information model.
Object-oriented (o-o) programming uses '''Object''' to manage data. Objects have identity, state, and behavior, which means Object is focus on identity and behavior of the things in real world. However '''relational database''' is focus on information. It is a collection of relation variables between the ''attributes'' of ''tables'', it describes the complete state of an information model.


Take the  
For instance, a "Customer Object" in on line bookstore system implemented by o-o programming constains the information of the customer such as name, address, email, and phone number. It also constains some methods operated by customer, such as "'''ordering_books'''", which defines the behavior of the customer.


==Object-relational Mapping==
==Object-relational Mapping==

Revision as of 16:03, 21 October 2007

Object-relational mapping. Ruby's ActiveRecord is one attempt to allow an object-oriented program to use a relational database. The Crossing Chasms pattern is another. Look up several approaches to mapping relational databases to o-o programs, include hyperlinks to all of them, and explain how they differ. Report on the strengths of various approaches (making sure to credit the authors for their insights).

Introduction

Object-oriented (o-o) programming uses Object to manage data. Objects have identity, state, and behavior, which means Object is focus on identity and behavior of the things in real world. However relational database is focus on information. It is a collection of relation variables between the attributes of tables, it describes the complete state of an information model.

For instance, a "Customer Object" in on line bookstore system implemented by o-o programming constains the information of the customer such as name, address, email, and phone number. It also constains some methods operated by customer, such as "ordering_books", which defines the behavior of the customer.

Object-relational Mapping

Object-relational mapping is a programming technique or process to transform data between relational database and a set of objects in object-oriented programming.

Implementations

ActiveRecord in Ruby

Active Record connects business objects and database tables to create a persistable domain model where logic and data are presented in one wrapping. It’s an implementation of the object-relational mapping (ORM) pattern

Crossing Chasms Pattern

Hibernate

Service Data Object

Comparison

In Hibernate, you'd usually begin development by working on your Java objects because Hibernate is a mapping framework. The object model becomes the center of your Hibernate universe. Active Record is a wrapping framework, so you start by creating a database table. The relational schema is the center of your Active Record universe. Active Record also includes some features that many Java frameworks don't have, such as model-based validation.Model-based validation lets you make sure the data within your database stays consistent.

Reference

  1. Wikipedia Definition
  2. Foundations of Object-Relational Mapping
  3. ORM Thesis[1]
  4. Crossing borders: Exploring Active Record

External Links

  1. O/R Mapping Products

222. [2]