System and method for managing object to relational one-to-many mapping
Instructions are generated to manipulate target objects and relationships in a relational database when a source object having a one-to-many relationship of privately owned type with the target objects is manipulated. To generate instructions, mapping meta-data is used which contains information as to how object classes of the object model map to tables in the database and how relationships map to foreign keys.
Latest Oracle Patents:
- User discussion environment interaction and curation via system-generated responses
- Model-based upgrade recommendations using software dependencies
- Providing local variable copies of global state for explicit computer executable instructions depending whether the global state is modified
- Efficient space usage cache on a database cluster
- Biometric based access control for DaaS
This application is a continuation of, and hereby claims priority under 35 U.S.C. section 120 to, a pending U.S. Patent Application entitled, “System and Method for Managing Object to Relational One-To-Many Mapping,” by inventors Yaoping Wang and James Bryce Sutherland, Ser. No. 11/062,014, filed 18 Feb. 2005, which in itself if a continuation of U.S. patent application Ser. No. 09/920,789, entitled, “System and Method for Managing Object to Relational One-To-Many Mapping,” by inventors Yaoping Wang and James Bryce Sutherland, filed on 1 Aug. 2001 (which issued as U.S. Pat. No. 6,907,433 on 14 Jun. 2005).
BACKGROUND OF THE INVENTIONObject model technology is becoming more popular for building enterprise applications. However, many organizations have already developed relational databases and have their corporate data stored in those databases. Accordingly, it is desirable to provide a mechanism to allow object applications to manipulate objects in relational databases, i.e., write, read, delete and update objects in or from the relational databases. Object-oriented applications are built using object models with inheritance and relationships, whereas relational databases consist of flat tables and foreign keys. It is desired to be able to represent the raw database data as application objects. Databases are queried through a database query language, such as Structured Query Language (SQL), however it is desirable to query object model at the object level and through traversing the object model.
In an object model, for a one-to-many relationship, the source object holds the references to the target objects. This is opposite to a relational database, where the target of the one-to-many relationship stores a foreign key to the source entity. It is desirable to represent a one-to-many relationship in the object model without having the target object have any knowledge, relationship to or foreign key information of the source object. The problem is that this information is required to store the target object into the relational database.
In order to store target objects into the relational database, an existing solution provides the target object in an object model with a many-to-one relationship back to the source object. The shortcomings of having a many-to-one relationship back to the source object is that the target object must have knowledge of the source object. This is intrusive of the object design and prevents other objects in the object model from sharing references to the same target object's class.
Another existing solution provides the target object in an object model with a direct attribute to store the foreign key to the source object. The shortcomings of having a direct attribute to store the foreign key to the source object is that the target object must have knowledge of the source object. This is again intrusive of the object design. In this solution, the foreign key attribute must also be maintained by the application's code.
It is therefore desirable to provide a system and method which allow object to relational one-to-many mapping without providing back-reference or direct attributes in the target objects.
SUMMARY OF THE INVENTIONIt is an object of the invention to provide a novel system and method for managing object to relational one-to-many mapping that obviates or mitigates at least one of the disadvantages of existing systems.
The present invention generates instructions to manipulate target objects and relationships in a relational database when a source object having a one-to-many relationship of privately owned type with the target objects is manipulated. To generate instructions, it uses mapping meta-data which contains information as to how object classes of the object model map to tables in the database and how relationships map to foreign keys.
In accordance with an aspect of the present invention, there is provided a method for managing object to relational one-to-many mapping for an object model mapped to a relational database. The method comprises steps of obtaining, for a source object having a primary key value and being manipulated in a corresponding source table of the relational database, mapping meta-data including information of a corresponding target table for storing at least target object with which the source object has a one-to-many relationship of privately owned type and information of a foreign key of the corresponding target table; generating an instruction to manipulate the at least one target object in the corresponding target table based on the mapping meta-data; and manipulating the at least one target object in the database by executing the instruction on the database.
In accordance with another aspect of the present invention, there is provided a method for managing object to relational one-to-many mapping for an object model mapped to a relational database. The method comprises steps of obtaining, for a source object having a primary key value and being inserted in a corresponding source table of the relational database, mapping meta-data including information of a corresponding target table for storing at least one target object with which the source object has a one-to-many relationship of privately owned type and information of a foreign key of the corresponding target table; generating an insert instruction to add a value of the foreign key based on the primary key value of the source object, and to insert the at least one target object into the corresponding target table based on the mapping meta-data; and inserting the at least one target object into the database by executing the insert instruction on the database.
In accordance with another aspect of the present invention, there is provided a method for managing object to relational one-to-many mapping for an object model mapped to a relational database. The method comprises steps of obtaining, when a source object having a primary key value is being read from a source table in the relational database, mapping meta-data including information of one or more corresponding target tables and information of one or more foreign keys of the corresponding target tables; generating a select instruction to select from the target tables target objects with which the source object has one-to-many relationships of privately owned type, based on the mapping meta-data and the primary key value of the source object; and reading the target objects and relationships relating to the source object from the database by executing the select instruction on the database.
In accordance with another aspect of the present invention, there is provided a method for managing object to relational one-to-many mapping for an object model mapped to a relational database. The method comprises steps of obtaining, when a source object having a primary key value is being deleted from a source table in the relational database; mapping meta-data that defines one or more corresponding target tables storing target objects with which the source object has one-to-many relationships of privately owned type and foreign key information; generating a delete instruction to delete the target objects from the target tables based on the mapping meta-data; and deleting the target objects by executing the delete instruction on the database.
In accordance with another aspect of the present invention, there is provided a method for managing object to relational one-to-many mapping for an object model mapped to a relational database. The method comprises a step of tracking changes to relationships and target objects with which the source object has one-to-many relationships of privately owned type, wherein the tracking step comprises steps of creating, at the start of a transaction, a source clone of a source object having a primary key value, a relationship clone of a relationship in the source object, and a target clone of target objects referenced by the relationship; and determining, when the transaction is committed, changes to the source object and target objects by comparing the source clone to the current state of the source object, and comparing the target clone to the current state of the target objects using the primary key value of the source object added to the target objects.
In accordance with another aspect of the present invention, there is provided a one-to-many mapping manager for managing object to relational one-to-many mapping for an object model mapped to a relational database. The system comprises a meta-data receiver for obtaining, for a source data having a primary key value and being manipulated, mapping meta-data including information of one or more corresponding target tables for storing multiple target objects with which the source object has one-to-many relationships of privately owned type and information of one or more foreign keys of the corresponding target tables; an instruction generator for generating instructions to manage the multiple target objects and the relationship based on the mapping meta-data; and an instruction executor for executing the instructions on the database and managing the target objects and the relationship in the database in accordance with the manipulation of the source object.
In accordance with another aspect of the present invention, there is provided a mapping system for managing an object model to a relational database. The object model contains object classes having one or more source objects and target objects having one-to-many relationships of privately owned type with the source objects. The database has tables including one or more source tables for storing the source objects and one or more target tables for storing the target objects. The source tables have primary keys and the target tables have foreign keys. The system comprises a mapping tool for assisting in mapping object classes to tables and mapping relationships to foreign keys; a meta-data storage for storing mapping meta-data defining information of how object classes map to tables and information of how relationships map to foreign keys, the mapping meta-data including information of one or more corresponding target tables for storing the multiple target objects and information of one or more foreign keys of the corresponding target tables; and a runtime mapping library for accessing the mapping meta-data in the meta-data storage and managing object data in the database, the runtime mapping library having a one-to-may mapping manager for managing one-to-many relationships and target objects with which a source objects have one-to-many relationships in accordance with the manipulation of the source object.
Other aspects and features of the present invention will be readily apparent to those skilled in the art from a review of the following detailed description of preferred embodiments in conjunction with the accompanying drawings.
The invention will be further understood from the following description with reference to the drawings in which:
One-to-many relationships can be composed into two groups, privately owned and independent. A privately owned relationship is one in which the target object is a dependent part of the source object and cannot exist on its own without the source object. The present invention handles the object to relational persistence of one-to-many relationships that are part of privately-owned group.
Target objects in Phone# 14 are a dependent part of the source object in Employee 12 and cannot exist without the source objects. Thus, Phone# is privately owned by Employee 12.
The class mapping tool 102 is a development-time tool that assists developers of the database schema in defining how an object model maps to a relational database. For example, using this tool 102, a developer maps the three object classes, Employee 12, Address 14 and Phone# 16, of object model 10 shown in
The meta-data storage 104 stores mapping meta-data defining the mapping data of how the object classes map to the tables, and how the relationships map to the foreign keys. The mapping meta-data comprises descriptors and mappings. A descriptor is a set of properties and mappings that describes how an object data is represented in a relational database. The descriptor contains mappings from the class attributes to the table columns, as well as the transformation routines necessary for storing and retrieving attributes. The descriptor acts as the link between the object model and the database representation. A mapping accomplishes the storage and retrieval of an object's attributes in and from the database representation.
The mapping meta-data may be stored in eXtended Markup Language (XML) files. The XML files are read in at runtime by the mapping manager 120 as further described below. The mapping meta-data is generally generated by the mapping tool 102. However, it may be specified through manually editing the XML file, or through Application Programming Interface (API) code. The meta-data storage 104 provided is external to both the source object classes and target object classes. Thus, there is no need to store additional information in the object classes.
The runtime mapping library 106 is a library storing a set of pre-defined generic mapping methods. The methods are defined such that they are executable on the database in terms of the object model, rather than the relational model. The runtime mapping library 106 executes the mapping methods on the database using the mapping meta-data to store or retrieve objects in or from the database. This allows users to use the mapping system 100 without knowledge of database access API's or database querying languages, such as Structured Query Language (SQL). Users may handle data in the database 20 at the object level using an object-based language, such as the Java™ programming language.
The one-to-many mapping manager 120 is a runtime component to dynamically manage the objects having one-to-many relationships. It comprises an instruction generator 122 and an instruction executor 124. The instruction generator 122 uses the mapping meta-data from the meta-data storage 104 at runtime to dynamically generate instructions to persist the objects. The instruction executor 124 executes the instructions on the database.
In
When a source object having a one-to-many relationship with multiple target objects is manipulated, the mapping manager 120 manages the target objects and the relationship. That is, when a source object is inserted into the database, the mapping manager 120 inserts the relationship and target objects to the database. When a source object is read from the database, the mapping manager 120 reads the relationship and the target objects from the database. When a source object is deleted from the database, the mapping manager 120 deletes the relationship and target object from the database. When a source object is changed in the database, the mapping manager 120 tracks changes to the relationship and the target objects and updates them to the database. These functions are further described in more detail below.
As shown in
The mapping manager 120 reads mapping meta-data from the meta-data storage 104 (140). The mapping meta-data may be read on every read request, periodically or any time as desired. It is however typically read once when the mapping system 100 is initialized. The mapping meta-data includes mapping information relating to a source object of interest and its multiple target objects with which the source object has a one-to-many relationship. That is, the retrieved mapping meta-data includes information of a corresponding source table for storing the source object, one or more corresponding target tables for storing the multiple target objects, and information of a foreign key of each corresponding target table.
The mapping manager 120 reads, from the object model, a source object and multiple target objects with which the source object has a one-to-many relationship (142).
When the source object is inserted into the corresponding source table (144), the mapping manager 120 generates insert instructions based on the mapping meta-data (146). The insert instructions cause values of the foreign key to be added based on the primary key of the source object, and causes the multiple target objects to be inserted into the corresponding target tables based on the mapping meta-data. The mapping manger 120 executes the insert instructions on the database and inserts the target objects into the target tables together with the foreign key values (148). Thus, the actual values for the foreign keys are passed down from the primary key value of the source object in which context the target objects are written.
The generation of the insert instructions (146) and the execution of the insert instructions (148) may be carried out by iterating over the target objects in the context of the source object. The iteration is further described referring to
The mapping manager 120 builds in memory a database row representation 180 of the first target object 170 (200). The database row representation 180 contains the target object data 170. This is only a temporary structure to store the target object data 170 for the generation and execution of the insert instruction. The representation 180 may be a Hashtable/Map-like structure. The mapping manager 120 adds the primary key value 162 of the source object 160 to the database row representation 180 (202). The primary key value 162 is added as a foreign key value of the target object.
The mapping manager 120 then generates an insert instruction based on row data for the target object (204). The row data includes the database row representation containing the target object data and the foreign key value, and the mapping meta-data obtained from the meta-data storage 104. The mapping meta-data specifies a target table 190 in which the target object is to be stored. As an insert instruction, an SQL Insert statement may be generated.
The mapping manager 120 executes the insert instruction on the database, and inserts the target object in a row 192 of the target table 190 (206). Steps 200 to 206 are repeated for each of other target objects (208).
By applying the steps shown in
Referring to
The mapping manager 120 uses mapping meta-data relating to the source object from the meta-data storage 104 (220). The mapping meta-data is typically read from the meta-data storage 104 when the mapping system 100 is initialized or any other time as desired, as described above. The source object has a primary key value. The retrieved mapping meta-data includes information about one or more corresponding target tables which store target objects of the source object, and information about the foreign key of each target table.
When the source object is read from the source table (222), the mapping manager 120 generates a select instruction 224 based on the mapping meta-data to select the target objects from the target tables (224). The mapping manager 120 executes the select instruction 224 on the database. The select instruction queries for all rows in the corresponding target tables that have a foreign key value matching the primary key value of the source object (226).
The select instruction 224 may be a SQL Select statement. The SQL Select statement may have a “select” clause and “where” clause. The foreign key values are not required in the target objects. The “select” clause does not include the foreign key field from each corresponding target table. It contains only the other relevant fields in each corresponding target table, whose data make up the target object data. The SQL Select statement checks the foreign key fields in the “where” clause to determine the primary key value matching.
The mapping manager 120 then translates the rows selected from the corresponding target tables into the target objects through using the mapping meta-data (228). This translation is carried out using the runtime mapping library 106. The runtime mapping library 106 has a mechanism called “reflection”. The reflection, using the mapping meta-data, instantiates the instance from the descriptor's class, and iterates over the descriptor's mappings to allow each mapping to set/load/transform its data into the target object. The reflection is non-intrusive to the object model.
The mapping manager 120 then adds the target objects to a collection that represents the value of the relationship of the source object (230). When all target objects are added to the collection, the mapping manager 120 sets the relationship value into the source object (232).
According to this method, the target objects are not required to store their complete primary key values. This is because part of their primary key may have been composed of the foreign key values. Because the target objects are privately owned by the source object, the target objects share their parent source object's primary key values. The target objects however store the additional part of their primary key values. This means that the target objects may only be uniquely identified in the context of their parent source object. If an object cache were being maintained, the target objects would not be directly cached, as they have no unique identity. They would be cached in the content of their owner, i.e., source object.
Referring to
When a source object is deleted from the database, the corresponding relationship and target objects are to be deleted. The source object in the database does not contain any reference to the target objects in the database. In order to delete the target objects in the database, the mapping manager 120 uses the mapping meta-data relating to the source object obtained from the meta-data storage 104 typically when the mapping system 100 is initialized or any other time as desired (240).
When a source object is deleted (242), the mapping system 100 determines whether the target objects are complex (244). The target objects are considered complex if they map to multiple tables.
If the target objects are not complex, the mapping manager 120 generates a single delete instruction based on the mapping meta-data (246). The mapping manager 120 executes on the database the delete instruction that deletes all rows from the target table that have a foreign key value matching the primary key value of the source object (248).
If the target objects are complex (244), the mapping manager 120 iterates over the target objects in the context of the source object to delete them one by one as joins between the source table and target tables representing the one-to-many relationships are typically not usable in delete statements in the database. That is, for each target object, the mapping manager 120 extracts a primary key value of the target object's row in the target table (250) as the primary key of the target object's row may contain data that is not in the target object. To build the complete primary key value, it may be required to add the source object's primary key valued as typically the target object primary key is composed of the source object primary key, i.e., the target object foreign key, and another field or value unique in the context of the source object. For example, for a table DEPARTMENT having a one-to-many relationship to a table EMPLOYEE, the complete primary key value may be the employee id and the foreign key value of the EMPLOYEE to the DEPARTMENT.
The mapping manager 120 then generates a delete instruction to delete the target object's row with the primary key values (252). The delete instruction may be a SQL Delete statement. The mapping manager 120 executes the delete instruction on the database to delete the row with the primary key value (254). Steps 250-254 are repeated for all target object (256).
Referring to
Changes are traced in the context of a transaction through an object cloning mechanism. The mapping manager 120 uses the same mapping meta-data to determine which objects have been added, removed or changed in the relationship.
At the start of a transaction, the mapping manager 120 creates clones for the source object, the relationship and the target objects (260). When the transaction is committed i.e., the changes made during the transaction are loaded into the object model 10, the mapping manger 120 computes changes to the source and target objects through comparing the clones to the current state of the objects (262). For the target objects that do not store in-memory their full primary key from the database and thus have no unique identity, the comparison is carried out in the context of the source object, so that the target objects have the primary key of the source object and their additional primary key values are unique.
This comparison enables the added, removed and changed objects to be identified (264). The mapping manager 120 then, using the mapping meta-data, generates the appropriate insert, delete or update instructions for each of the target objects (266, 268, 270). For example, SQL Insert statements are generated for objects that have been added, SQL Delete statements are generated for objects that have been removed, and SQL Update statements are generated for objects that have been changed.
The above embodiments are described using Java technology as an example of an object based technology and language. However, the applicability of the invention is not limited to Java or Java based technologies. The invention may be applied to other object-based languages and technologies, such as those developed by Microsoft Corporation or Hewlett Packard, with or without appropriate modification as necessary or desired, and such application is within the scope of the invention.
Similarly, while the above embodiments are described using SQL as an example of a query language, the invention is not limited to technologies based on or SQL or employing SQL. The invention may be applied incorporating other database query languages with or without appropriate modification as necessary or desired, and such application is still within the scope of the invention.
The mapping managing system of the present invention may be implemented by any hardware, software or a combination of hardware and software having the above described functions. The hardware may be a general purpose computer, or a part of a general purpose computer. The software code, either in its entirety or a part thereof, may be stored in a computer readable memory. Further, a computer data signal representing the software code which may be embedded in a carrier wave may be transmitted via a communication network. Such a computer readable memory and a computer data signal are also within the scope of the present invention, as well as the hardware, software and the combination thereof.
While particular embodiments of the present invention have been shown and described, changes and modifications may be made to such embodiments without departing from the true scope of the invention.
Claims
1. A computer implemented method for managing object to relational one-to-many mapping in a relational database, the method comprising:
- creating, at a computer, a source clone of a source object in an object model wherein the source object has a primary key value from a source table of the relational database, a relationship clone of a one-to-many relationship in the object model corresponding to the source object, and a target clone of target objects in the object model referenced by the relationship wherein the target objects have foreign key values from target tables of the relational database;
- retrieving, by the computer, mapping meta-data via a runtime mapping library, wherein the mapping meta-data describes how class attributes of the source object map to columns in the source table, and how the relationship maps to foreign keys in target tables corresponding to the target objects, wherein the foreign keys have the primary key value;
- determining, by the computer, changes to the source clone and target clone by comparing the source clone with the source object in the object model, and comparing the target clone with the target objects in the object model; and
- generating, by the computer, a set of database instructions to update changes to the source and target tables in the relational database.
2. The computer implemented method as claimed in claim 1, further comprising:
- updating the relationship between the source object and the target objects by: determining which objects have been added, removed or changed in the relationship by examining the mapping meta-data including information of corresponding source table, one or more target tables and foreign keys of the target tables, generating an INSERT instruction for each target object of a source target that has been added, generating a DELETE instruction for each target object of a source target that has been removed, and generating an UPDATE instruction for each target object of a source target that has been changed; and producing and storing a new database that results from updating the relationships between the source object and the target objects.
3. The computer implemented method as claimed in claim 2, wherein generating the INSERT, DELETE, and UPDATE instructions comprises one or more of:
- generating SQL INSERT statements for objects that have been added;
- generating SQL DELETE statements for objects that have been removed; and
- generating SQL UPDATE statements for objects that have been changed.
4. The computer implemented method as claimed in claim 1 further comprising a step of:
- storing the mapping meta-data external to the source object class and the target object classes.
5. The computer implemented method as claimed in claim 4, wherein storing the mapping meta-data comprises storing the mapping meta-data as XML files.
6. A system for managing object to relational one-to-many mapping in a relational database, the system comprising:
- a computer-readable memory storing mapping metadata in a runtime mapping library storing, wherein the mapping meta-data describes how class attributes of the source object map to columns in the source table, and how the relationship maps to foreign keys in target tables corresponding to target objects, wherein the foreign keys have the primary key value;
- an instruction generator for generating instructions to: create a source clone of the source object in an object model wherein the source object has a primary key value from a source table of the relational database, a relationship clone of a one-to-many relationship corresponding to the source object, and a target clone of the target objects in the object model referenced by the relationships wherein the target objects having foreign key values from target tables of the relational database; determine changes to the source clone and target clone by comparing the source clone with the source object in the object model and comparing the target clone with the target objects in the object model; and generate a set of database instructions to update changes to the source and target tables in the relational database.
7. The manager system as claimed in claim 6, wherein the instruction generator comprises an INSERT instruction generator for generating INSERT instructions to insert the target objects into the corresponding target tables based on the mapping meta-data when a source object is inserted into the database.
8. The manager system as claimed in claim 7, wherein the INSERT instruction generator includes:
- a representation builder for building a database row representation for each target object; and
- a primary key information adder for adding the primary key value of the source object to the database row representation.
9. The manager system as claimed in claim 7, wherein the instruction generator generates the INSERT instructions as SQL Insert statements.
10. The manager system as claimed in claim 6, wherein the instruction generator comprises a READ instruction generator for generating READ instructions to read the target objects and the relationships from the one or more corresponding target tables and the foreign key values based on the mapping meta-data when a source object is read from the database.
11. The manager system as claimed in claim 10, wherein the instruction generator generates the READ instructions as SQL Select statements.
12. The manager system as claimed in claim 6, wherein the instruction generator comprises a DELETE instruction generator for generating delete instructions to delete the target objects and the relationships from the one or more corresponding target tables and foreign key values based on the mapping meta-data when the source object is deleted from the database.
13. The manager system as claimed in claim 12, wherein the instruction generator generates the DELETE instructions as SQL Delete statements.
14. The manager system as claimed in claim 6, wherein the instruction generator generates the instructions as SQL INSERT statements, SQL DELETE statements or SQL UPDATE statements depending on the change to the source object.
15. A non-transitory computer-readable storage medium storing instructions that when executed by a computer cause the computer to perform a method for managing object to relational one-to-many mapping in a relational database, the method comprising:
- creating a source clone of a source object in an object model wherein the source object has a primary key value from a source table of the relational database, a relationship clone of a one-to-many relationship in the object model corresponding to the source object, and a target clone of target objects in the object model referenced by the relationship wherein the target objects have foreign key values from target tables of the relational database;
- retrieving mapping meta-data via a runtime mapping library, wherein the mapping meta-data describes how class attributes of the source object map to columns in the source table, and how the relationship maps to foreign keys in target tables corresponding to the target objects, wherein the foreign keys have the primary key value;
- determining changes to the source clone and target clone by comparing the source clone with the source object in the object model, and comparing the target clone with the target objects in the object model; and
- generating a set of database instructions to update changes to the source and target tables in the relational database.
16. The computer-readable memory as claimed in claim 15, wherein the method further comprises:
- updating the relationship between the source object and the target objects by: determining which objects have been added, removed or changed in the relationship by examining the mapping meta-data including information of corresponding source table, one or more target tables and foreign keys of the target tables, generating an INSERT instruction for each target object of a source target that has been added, generating a DELETE instruction for each target object of a source target that has been removed, and generating an UPDATE instruction for each target object of a source target that has been changed; and producing and storing a new database that results from updating the relationships between the source object and the target objects.
17. The computer-readable memory as claimed in claim 16, wherein generating the INSERT, DELETE and UPDATE instructions comprise one or more of:
- generating SQL INSERT statements for objects that have been added;
- generating SQL DELETE statements for objects that have been removed; and
- generating SQL UPDATE statements for objects that have been changed.
18. The computer-readable memory as claimed in claim 15, further comprising:
- storing the mapping meta-data external to a source object class and target object classes.
19. The computer-readable memory as claimed in claim 18, wherein storing the mapping meta-data comprises storing the mapping meta-data as XML files.
4930071 | May 29, 1990 | Tou et al. |
5499371 | March 12, 1996 | Henninger et al. |
5560014 | September 24, 1996 | Imamura |
5615362 | March 25, 1997 | Jensen et al. |
5706506 | January 6, 1998 | Jensen et al. |
5799309 | August 25, 1998 | Srinivasan |
6078926 | June 20, 2000 | Jensen et al. |
6101502 | August 8, 2000 | Heubner et al. |
6122641 | September 19, 2000 | Williamson et al. |
6163776 | December 19, 2000 | Periwal |
6385618 | May 7, 2002 | Ng et al. |
6631519 | October 7, 2003 | Nicholson et al. |
20020091702 | July 11, 2002 | Mullins |
Type: Grant
Filed: Jun 2, 2008
Date of Patent: May 17, 2011
Patent Publication Number: 20080235272
Assignee: Oracle International Corporation (Redwood Shores, CA)
Inventors: Yaoping Wang (Ottawa), James Bryce Sutherland (Ottawa)
Primary Examiner: Leslie Wong
Assistant Examiner: Shiow-Jy Fan
Attorney: Park, Vaughan, Fleming & Dowler LLP
Application Number: 12/131,811
International Classification: G06F 17/30 (20060101);