This description relates to managing changes to collections of data.
Computing systems, such as database systems, provide various mechanisms for managing changes in collections of data. In some cases, users propose and implement changes to data stored in databases. In general, databases include rules that define how the stored data can be altered.
In one aspect, in general, a method for managing changes to a collection of records includes storing a first set of records in a data storage system, the first set of records representing a first version of the collection of records. The method further includes validating a proposed change to the collection of records specified by an input received over a user interface. The validating includes: querying the data storage system based on validation criteria associated with the proposed change and receiving a first result in response to the querying, processing a second set of records representing changes not yet applied to the collection of records to generate a second result, updating the first result based on the second result to generate a third result, and processing the third result to determine whether the proposed change is valid according to the validation criteria.
In another aspect, in general, a computer-readable storage medium stores a computer program for managing changes to a collection of records. The computer program includes instructions for causing a computing system to: store a first set of records in a data storage system, the first set of records representing a first version of the collection of records; and validate a proposed change to the collection of records specified by an input received over a user interface. The validating includes: querying the data storage system based on validation criteria associated with the proposed change and receiving a first result in response to the querying, processing a second set of records representing changes not yet applied to the collection of records to generate a second result, updating the first result based on the second result to generate a third result, and processing the third result to determine whether the proposed change is valid according to the validation criteria.
In another aspect, in general, a computing system for managing changes to a collection of records includes: a data storage system storing a first set of records, the first set of records representing a first version of the collection of records; and at least one processor configured to validate a proposed change to the collection of records specified by an input received over a user interface. The validating includes: querying the data storage system based on validation criteria associated with the proposed change and receiving a first result in response to the querying, processing a second set of records representing changes not yet applied to the collection of records to generate a second result, updating the first result based on the second result to generate a third result, and processing the third result to determine whether the proposed change is valid according to the validation criteria.
In another aspect, in general, a computing system for managing changes to a collection of records includes: means for storing a first set of records, the first set of records representing a first version of the collection of records; and means for validating a proposed change to the collection of records specified by an input received over a user interface. The validating includes: querying the data storage system based on validation criteria associated with the proposed change and receiving a first result in response to the querying, processing a second set of records representing changes not yet applied to the collection of records to generate a second result, updating the first result based on the second result to generate a third result, and processing the third result to determine whether the proposed change is valid according to the validation criteria.
Aspects can include one or more of the following features. The first set of records includes a metadata map that maps one or more source values to respective target values. The proposed change is invalidated if one of the one or more source values are mapped to two or more different target values. Processing the third result includes identifying whether applying the proposed change would result in a creation of one or more duplicate records. Identifying whether applying the proposed change would result in a creation of one or more duplicate records includes identifying one or more duplicate rows. The one or more duplicate rows are identified using one or more source values as the validation criteria. The second set of records includes one or more changesets that represent proposed changes to the first set of records that have been entered into a user interface. The input includes an instruction to apply changes associated with a previously-saved changeset to the first set of records. Validating the proposed change to the collection of records includes validating the proposed change against other proposed changes specified in the user interface by the input. The user interface includes one or more filters to selectively display one or more subsets of sets of records. A notification is generated if the proposed change is not validated. The notification identifies a portion of the proposed change that violates the validation criteria.
Aspects can include one or more of the following advantages. For example, the techniques described herein can be used to maintain the integrity and accuracy of various databases and files. The techniques described herein may also allow an administrator to efficiently maintain one or more record systems.
Other features and advantages of the invention will become apparent from the following description, and from the claims.
A processing environment 106 includes a processing engine 108 and a validation engine 110. The processing environment 106 may be hosted on one or more general-purpose computers under the control of a suitable operating system, such as the UNIX operating system. For example, the processing environment 106 can include a multiple-node parallel computing environment including a configuration of computer systems using multiple central processing units (CPUs), either local (e.g., multiprocessor systems such as SMP computers), or locally distributed (e.g., multiple processors coupled as clusters or MPPs), or remotely, or remotely distributed (e.g., multiple processors coupled via a local area network (LAN) and/or wide-area network (WAN)), or any combination thereof.
Storage devices providing the data storage system 112 may be local to the processing environment 106, for example, being stored on a storage medium connected to a computer running the processing environment 106 (e.g., a hard drive), or may be remote to the processing environment 106, for example, being hosted on a remote system (e.g., a mainframe) in communication with a computer running the processing environment 106, over a remote connection.
The processing environment 106 (and/or its associated components, such as the processing engine 108) can receive data from a variety of types of systems including different forms of database systems. The data may be organized as records having values for respective fields (also called “attributes” or “columns”), including possibly null values. When first reading data from a data source, the processing environment 106 typically starts with some initial format information about records in that data source. In some circumstances, the record structure of the data source may not be known initially and may instead be determined after analysis of the data source. The initial information about records can include the number of bits that represent a distinct value, the order of fields within a record, and the type of value (e.g., string, signed/unsigned integer) represented by the bits.
The computing environment 100 also includes a user interface 102 configured to communicate commands from a user 101 to the processing environment 106. In some examples, and as described in further detail below, the user 101 can use the user interface 102 to input a proposed record change 104. For example, the user 101 may attempt to alter one or more records in a set of records 116 stored in the data storage system 112 by entering a proposed record change 104 that includes the addition and/or deletion of rows or columns from a table in the set of records 116, or changes to the values in one or more fields of a table. The user interface 102 can also communicate information from the processing environment 106 to the user 101 using a variety of output devices, such as computer displays, speakers, and the like. For example, the user interface 102 can include a graphical display that can graphically represent the information stored in the data storage system 112 (e.g., by displaying a grid that represents the columns and rows of a database table).
The processing engine 108 and the validation engine 110 use the proposed record change 104 and information retrieved from the data storage system 112 to validate and/or implement changes to the set of records 116 stored in the data storage system 112. The information retrieved from the data storage system 112 can include information related to one or more pending record changes 114 (e.g., changes to the set of records 116 that have not yet been implemented, but may have already been validated and/or saved). In some examples, the pending record changes are referred to as “changesets.” In general, the processing engine 108 receives and processes record data, including data that represents instructions for altering one or more sets of records. The processing engine 108 may use data from the proposed records change 104, the pending records changes 114, and the set of records 116 to generate or execute instructions for changing the set of records 116 stored in the data storage system 112. In some examples, the validation engine 110 validates the instructions for changing the collection of records before the instructions are executed (e.g., by the processing engine 108) to alter the collection of records. While the processing environment 106 contains both the processing engine 108 and the validation engine 110, the processing environment 106 can divide its tasks among any number of individual task engines. For example, a single task engine could perform the functions of both the processing engine 108 and the validation engine 110. Similarly, the tasks performed by the processing engine 108 and the validation engine 110 could be divided among a plurality of sub task engines.
The data stored in the data storage system 112 is accessible to the processing environment 106. The data storage system 112 may also be directly or indirectly accessible to the user interface 102 in which a developer 101 is able to propose and implement changes to the data stored in the data storage system 112. In some examples, the user interface 102 is associated with a development environment for developing applications such as dataflow graphs that include vertices (representing components or datasets) connected by directed links (representing flows of work elements) between the vertices. For example, such an environment is described in more detail in U.S. Publication No. 2007/0011668, entitled “Managing Parameters for Graph-Based Applications,” incorporated herein by reference. A system for executing such graph-based computations is described in U.S. Pat. No. 5,566,072, EXECUTING COMPUTATIONS EXPRESSED AS GRAPHS, incorporated herein by reference. Dataflow graphs made in accordance with this system provide methods for getting information into and out of individual processes represented by graph components, for moving information between the processes, and for defining a running order for the processes. This system includes algorithms that choose interprocess communication methods (for example, communication paths according to the links of the graph can use TCP/IP or UNIX domain sockets, or use shared memory to pass data between the processes).
A first set of records is stored (202) in a data storage system, the first set of records representing a first version of a collection of records. In some examples, the collection of records represents a collection of information that is to be accurately maintained and updated for use in processing data, such as metadata maps. In general, a metadata map can specify a translation of values between two different systems. For example, if a first system uses the values M (male) and F (female) to define a “gender” field, and a second system uses the values 0 (male) and 1 (female) to define the gender field, a metadata map can be used to translate values from the first (“source”) system to the second (“target”) system (e.g., M→0, F→1). Mappings can be made between single fields or between sets of fields (e.g., mapping multiple columns from a first system to a second system). For example, consider a first system that stores a record containing a first column representing a gender of a person and a second column representing a state in which the person lives. In this example, the gender code may depend on the states, where a first gender code mapping is used for one state and a second gender code mapping is used for another state. Records with the state MA may map the value 1 to Male, but records with the state NY may map the value 3 to male. In this example, the combination MA/0 maps to Male, the combination MA/1 maps to Female, and the combination NY/3 maps to male.
In some examples, metadata maps provide a translation from one (and only one) source value to a target value. In these examples, metadata maps cannot provide a translation for M→0 as well as F→0, as such a translation could cause an error. This manner of translation would essentially destroy the distinction between “M” and “F,” as the two different source values would be mapped to the same target value. Accordingly, in many cases, each target value may only be associated with one source value. In other implementations, if it is not desirable for a target system to maintain a distinction between two differing source values (e.g., M and F), then multiple source values could be mapped to the same target value.
A proposed change to the collection of records specified by an input is validated (204). In some examples, validating (204) the proposed change includes a validation process 205 that includes the procedures 206, 208, 210, and 212. That is, in validating (204) the proposed change, the data storage system is queried based on validation criteria associated with the proposed change, and a first result is received in response to the query (206). For example, after receiving information about the proposed record change 104, the processing engine 108 queries the data storage system 112. In some examples, querying the data storage system 112 causes the data storage system 112 to return a first result that identifies rows and/or columns which are relevant to the rows and/or columns affected by the proposed changes 104. The validation criteria on which the query is based represent a set of values from source or target columns of a particular row. For example, source column validation criteria can be used to validate that implementing the proposed change 104 will not result in duplicate rows in the set of records 116, while values from target columns can be used to validate that a map between source and target values is reversible (e.g., to confirm that each set of target values is unique). The processing engine 108 may store the first result (e.g., in local memory) for later use in validating the proposed record change 104.
To generate a second result, a second set of records (“changesets”) is processed that represents changes not yet applied to the collection of records (208). For example, the processing engine 108 can processes the pending record changes 114 stored in the data storage system 112 in order to generate a second result that represents changes that may conflict with the proposed record change 104. For example, if the proposed record change 104 contained an instruction to modify a value of row X the processing engine could extract any instructions from the pending record changes 114 that relate to row X. The information extracted from the pending record changes 114 is stored (e.g., in local memory) as the second result. In some implementations, the processing engine 108 can pass the first result to the validation engine 110 in order to validate the proposed record change 104 without considering the pending record changes 114. Similarly, the processing engine 108 can pass the second result to the validation engine 110 in order to validate the pending record changes 114 without considering the proposed record change 104. In some examples, changesets can be generated using one or more of the environments and techniques shown in
The first result is updated based on the second result to generate a third result (210). For example, after a generation of the first and second result in the manner discussed above, the processing engine 108 can update the first result with information from the second result to generate a third result. In some examples, the third result includes rows and/or columns identified in the first and second results. The third result can be processed to determine whether the proposed change is valid according to the validation criteria (212). For example, the processing engine 108 can pass the third result and the proposed record change 104 to the validation engine 110. The validation engine 110 can then compare the proposed record change 104 (e.g., using the validation criteria identified in the proposed record change 104) to determine whether the proposed record change 104 is valid (214). Determining whether the proposed changes to the set of records is valid may include one or more of checking for duplicate source values, verifying that each set of source values maps to a unique set of target values, and verifying that any ranges (e.g., date ranges) do not overlap.
If the proposed change was determined to be invalid (NO), the proposed change is rejected (218). One or more user notifications can also be generated (220). In some examples, the notifications can identify one or more reasons why the proposed change was invalidated. For example, if the validation engine 110 rejects a proposed change because the proposed change includes instructions to modify a row that has been deleted in the pending record change 114, a notification can be generated on the user interface 102 that identifies the conflict between the proposed record change 104 and the pending record changes 114.
If the proposed change is determined to be valid (YES), the proposed change can be applied to the collection of records. For example, if the validation engine 110 determines that the proposed change 104 are valid according to the validation criteria, the processing engine 106 (or another suitable entity) can modify the set of records 116 according to the instructions provided in the proposed record change 104. For example, if the proposed record change 104 contains an instruction to modify a row in the set of records 116, and the validation engine 110 determines that the proposed record change 104 is valid according to the validation criteria, the processing engine 108 may modify a row in the set of records 116 identified in the proposed record change 104.
In some examples, the validation process querying rows from an external table based on a validation critieria, which may be either a set of source values or a set of target values. A data storage system (e.g., a metadata storage repository) may then be queried for saved rows on a current changeset that represent an update or a deletion of an external row. In some examples, this query of the data storage system might not use the validation criteria, because the nature of the override may mean that the resulting row no longer matches the validation criteria. External rows may be removed that no longer match the validation criteria based on the saved overrides from the data storage system. The data storage system may then be queried for rows that match the validation criteria. Some or all of the resulting rows that match the unique identifier of an external row that is already in the validation set may replace the corresponding external row. Other rows that match the validation criteria may then be added to the set. Finally any unsaved changes from a user interface may replace or remove existing rows with the same unique identifier from the validation set based on whether the latest change matches the validation criteria. Unsaved rows that match the validation criteria and represent new rows (e.g., inserts for the external table) may be added to the validation set. The final set of rows can then be used to apply the validation.
After a file has been selected, one or more filters 314 can be applied to the data associated with the selected file 303. The application of the filters 314 can alter the type or amount of data that will be displayed in the environment 300. For example, a filter 314 could be applied to the selected file 303 to suppress the display of rows for which target values have not been entered.
In this example, the selected file 303 is a metadata map. As discussed above, in general, a metadata map can be a translation of values between two different systems. In
The validation process can be triggered using a variety of techniques. For example, a user may activate a “validate change” control that instructs the validation engine 110 (
After the proposed change is invalidated, the conflicting row 409 can rendered in the environment 400B, even despite the application of the filter 402 which would otherwise suppress rows having a source value other than P002. In this case, the conflicting row 409 is rendered adjacent to the offending row (row 410) that represents the invalid proposed change. In addition, one or more notifications 414, 416 can be generated to draw a user's attention to the invalid proposed change. In order to correct the invalid proposed change, the user can either delete the proposed change, or can modify the proposed change and/or any conflicting values in order to satisfy the validation rule(s) that were violated.
The environment 400B also includes a save control 418 and a save and submit control 420 that can be activated by a user. In some examples, activation of the save control 418 will save any proposed changes entered by the user, but will not apply the proposed changes to the set of records (e.g., the data associated with the set of records will not be altered in response to activating the save control 418). Instead, activation of the save control 418 can cause the generation of a file (e.g., a changeset) that contains a saved proposed change that has not yet been applied to the set of records (e.g., the pending records changes 114 shown in
The techniques for managing changes to record collections described above can be implemented using software for execution on a computer. For instance, the software forms procedures in one or more computer programs that execute on one or more programmed or programmable computer systems (which may be of various architectures such as distributed, client/server, or grid) each including at least one processor, at least one data storage system (including volatile and non-volatile memory and/or storage elements), at least one input device or port, and at least one output device or port. The software may form one or more modules of a larger program, for example, that provides other services related to the design and configuration of dataflow graphs. The nodes and elements of the graph can be implemented as data structures stored in a computer readable medium or other organized data conforming to a data model stored in a data repository.
The software may be provided on a storage medium, such as a CD-ROM, readable by a general or special purpose programmable computer or delivered (encoded in a propagated signal) over a communication medium of a network to the computer where it is executed. All of the functions may be performed on a special purpose computer, or using special-purpose hardware, such as coprocessors. The software may be implemented in a distributed manner in which different parts of the computation specified by the software are performed by different computers. Each such computer program is preferably stored on or downloaded to a storage media or device (e.g., solid state memory or media, or magnetic or optical media) readable by a general or special purpose programmable computer, for configuring and operating the computer when the storage media or device is read by the computer system to perform the procedures described herein. The inventive system may also be considered to be implemented as a computer-readable storage medium, configured with a computer program, where the storage medium so configured causes a computer system to operate in a specific and predefined manner to perform the functions described herein.
A number of embodiments of the invention have been described. Nevertheless, it will be understood that various modifications may be made without departing from the spirit and scope of the invention. For example, some of the steps described above may be order independent, and thus can be performed in an order different from that described.
It is to be understood that the foregoing description is intended to illustrate and not to limit the scope of the invention, which is defined by the scope of the appended claims. For example, a number of the function steps described above may be performed in a different order without substantially affecting overall processing. Other embodiments are within the scope of the following claims.
This application claims priority to U.S. Application Ser. No. 61/433,082, filed on Jan. 14, 2011, incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5758351 | Gibson et al. | May 1998 | A |
5966072 | Stanfill et al. | Oct 1999 | A |
6494159 | Sirmalis et al. | Dec 2002 | B2 |
6708186 | Claborn et al. | Mar 2004 | B1 |
6948154 | Rothermel et al. | Sep 2005 | B1 |
7080088 | Lau | Jul 2006 | B1 |
7110924 | Prewett et al. | Sep 2006 | B2 |
7164422 | Wholey, III et al. | Jan 2007 | B1 |
7167850 | Stanfill | Jan 2007 | B2 |
7661067 | Chen et al. | Feb 2010 | B2 |
7689565 | Gandhi | Mar 2010 | B1 |
7716630 | Wholey et al. | May 2010 | B2 |
7765529 | Singh et al. | Jul 2010 | B1 |
7840949 | Schumacher et al. | Nov 2010 | B2 |
7853553 | Lankinen et al. | Dec 2010 | B2 |
7890509 | Pearcy et al. | Feb 2011 | B1 |
7895586 | Ozone | Feb 2011 | B2 |
8069129 | Gould et al. | Nov 2011 | B2 |
8423564 | Hayes | Apr 2013 | B1 |
8484159 | Stanfill et al. | Jul 2013 | B2 |
8516008 | Marquardt | Aug 2013 | B1 |
20010007959 | Abdalla | Jul 2001 | A1 |
20010014890 | Liu et al. | Aug 2001 | A1 |
20020161799 | Maguire et al. | Oct 2002 | A1 |
20020194196 | Weinberg | Dec 2002 | A1 |
20030016246 | Singh | Jan 2003 | A1 |
20030041063 | Brady | Feb 2003 | A1 |
20030154191 | Fish | Aug 2003 | A1 |
20030163441 | Godfredsen | Aug 2003 | A1 |
20030163597 | Hellman et al. | Aug 2003 | A1 |
20040015783 | Lennon et al. | Jan 2004 | A1 |
20040056908 | Bjornson et al. | Mar 2004 | A1 |
20040225682 | Murman | Nov 2004 | A1 |
20040239681 | Robotham et al. | Dec 2004 | A1 |
20050060313 | Naimat et al. | Mar 2005 | A1 |
20050060317 | Lott et al. | Mar 2005 | A1 |
20050114369 | Gould et al. | May 2005 | A1 |
20050178833 | Kisliakov | Aug 2005 | A1 |
20050187984 | Chen | Aug 2005 | A1 |
20050234762 | Pinto et al. | Oct 2005 | A1 |
20050262121 | Cesare et al. | Nov 2005 | A1 |
20060020570 | Wu | Jan 2006 | A1 |
20060095466 | Stevens et al. | May 2006 | A1 |
20060200739 | Bhatia et al. | Sep 2006 | A1 |
20060282480 | Johnson | Dec 2006 | A1 |
20070011208 | Smith | Jan 2007 | A1 |
20070027858 | Weinberg et al. | Feb 2007 | A1 |
20070050750 | Bykov et al. | Mar 2007 | A1 |
20070094060 | Apps et al. | Apr 2007 | A1 |
20070136692 | Seymour et al. | Jun 2007 | A1 |
20070179956 | Whitmyer, Jr. | Aug 2007 | A1 |
20070198457 | Olenick et al. | Aug 2007 | A1 |
20070226203 | Adya et al. | Sep 2007 | A1 |
20070239751 | Wei et al. | Oct 2007 | A1 |
20070271381 | Wholey et al. | Nov 2007 | A1 |
20070276787 | Piedmonte | Nov 2007 | A1 |
20070294119 | Eicher et al. | Dec 2007 | A1 |
20080049022 | Sherb et al. | Feb 2008 | A1 |
20080228697 | Adya et al. | Sep 2008 | A1 |
20080243772 | Fuxman et al. | Oct 2008 | A1 |
20080243891 | Super et al. | Oct 2008 | A1 |
20080256014 | Gould et al. | Oct 2008 | A1 |
20080312979 | Lee et al. | Dec 2008 | A1 |
20080313204 | Schultz et al. | Dec 2008 | A1 |
20090037488 | Abrams | Feb 2009 | A1 |
20090083313 | Stanfill et al. | Mar 2009 | A1 |
20090094291 | Yalamanchi | Apr 2009 | A1 |
20090319494 | Gooder | Dec 2009 | A1 |
20090327196 | Studer et al. | Dec 2009 | A1 |
20100100220 | Belanger et al. | Apr 2010 | A1 |
20100114833 | Mu | May 2010 | A1 |
20100121890 | Perkins et al. | May 2010 | A1 |
20100138383 | Winters et al. | Jun 2010 | A1 |
20100138388 | Wakeling et al. | Jun 2010 | A1 |
20100145914 | Kanno et al. | Jun 2010 | A1 |
20100198769 | Gould et al. | Aug 2010 | A1 |
20100223218 | Prendergast | Sep 2010 | A1 |
20110061057 | Harris et al. | Mar 2011 | A1 |
20110066602 | Studer et al. | Mar 2011 | A1 |
20110295863 | Weir et al. | Dec 2011 | A1 |
20120054164 | Falkebo et al. | Mar 2012 | A1 |
20120102029 | Larson et al. | Apr 2012 | A1 |
20120158625 | Nelke et al. | Jun 2012 | A1 |
20120167112 | Harris et al. | Jun 2012 | A1 |
20120185449 | Gould et al. | Jul 2012 | A1 |
20130166515 | Kung | Jun 2013 | A1 |
20140108357 | Procops | Apr 2014 | A1 |
Number | Date | Country |
---|---|---|
2221733 | Aug 2010 | EP |
H11-143755 | May 1999 | JP |
2006-277624 | Oct 2006 | JP |
Entry |
---|
Transaction History, U.S. Appl. No. 12/628,521. |
Transaction History, U.S. Appl. No. 12/883,721. |
Transaction History, U.S. Appl. No. 13/281,039. |
International Search Report & Written Opinion issued in PCT application No. PCT/US2011/057623, dated Jan. 25, 2012, 13 pages. |
International Search Report & Written Opinion issued in PCT application No. PCT/US2012/021286, dated May 4, 2012, 15 pages. |
Melia, Mark et al., “Constraint-Based Validation of Adaptive e-Learning Courseware,” IEEE Transactions on Learning Technologies, vol. 2, No. 1, Jan.-Mar. 2009, pp. 37-49. |
Rull, Guillem et al., “MVT: A Schema Mapping Validation Tool,” EDBT'09, Mar. 24-26, 2009, pp. 1120-1123. |
International Search Report & Written Opinion issued in PCT application No. PCT/US09/66210, mailed Jan. 27, 2010, 8 pages. |
International Search Report & Written Opinion issued in PCT application No. PCT/US10/49142, dated Nov. 5, 2010, 11 pages. |
Van Megen, Rudolf et al., “Costs and benefits of early defect detection: experiences from developing client server and host applications.” Software Quality Journal 4, 247-256 (1995). |
U.S. Appl. No. 12/628,521, filed May 7, 2014. |
U.S. Appl. No. 12/883,721, filed May 7, 2014. |
U.S. Appl. No. 13/281,039, filed May 7, 2014. |
U.S. Appl. No. 13/653,995, filed May 7, 2014. |
Chaiken et al., “Scope: easy and efficient parallel processing of massive data sets,” J. Proc. of the VLDB Endowment VLDB Endowment Hompagearchive, vol. 1, No. 2, (2008), pp. 1265-1276. |
Pinheiro et al., “Mobile agents for aggregation of network management data,” Published in Agent Systems and Applications, (1999) and Third International Symposium on Mobile Agents, Proceedings, First International Symposium, 1999, pp. 130-140. |
Japanese Office Action issued in JP2012-529903, dated Aug. 7, 2014, 4 pages (English Translation). |
Japanese Office Action issued in JP2011-539631, dated Oct. 24, 2013, 3 pages (English Translation). |
Harkins, Susan “Use Excel's Conditional Formatting to Find Errors” TechRepublic, pp. 1-3, Feb. 16, 2008: http://www.techrepublic.com/blog/microsoft-office/use-excels-conditional-formatting-to-find-errors/. |
International Search Report & Written Opinion issued in PCT application No. PCT/US2013/064979, dated Nov. 28, 2013, 11 pages. |
Liskin, Miriam “Microsoft Access 97 for Windows SuperGuide” Ziff-Davis Press, Jan. 1, 1997, ch. 4 & 15, pp. 117-157 and 687-739. |
Number | Date | Country | |
---|---|---|---|
20120185449 A1 | Jul 2012 | US |
Number | Date | Country | |
---|---|---|---|
61433082 | Jan 2011 | US |