The present invention relates generally to data searches, and more particularly to synonym supported searches in data stores.
To search data stored in databases, a database query needs to particularly specify what type of data is being searched. For example, if the data being searched is stored in a relational database table having multiple columns, the search query (e.g., an SQL Query) must specify which column or columns may include the data being searched.
Search engines have simplified searching for data stored in various types of data stores, in that a plain language search query may be used to retrieve data from various sources. Search engines generally browse through various data sources to create indexes. A search query is processed with the help of these indexes. The indexes generally include keywords and destinations the keywords in data stores.
However, the search query still must specify the exact words or phrases that need to be matched with the content of these various data sources. For example, if a search query includes the search criteria “home address” and if the underlying data source identifies this information as “house address,” the query would not retrieve the desired results. Some commercial search engines have built in logic to correct spelling mistakes in the search queries. Also, some commercial search engines are also configured to provide suggestions as to similar sounding terms for the searched terms.
Methods and systems for modifying search queries to add synonyms for words and phrases are disclosed. The modification of search queries also includes handling overlapping phrases in order to modify search queries to include synonyms for overlapping terms, if a synonym database provides synonyms for the overlapping terms.
In one embodiment, a method for performing a data search through a search query is disclosed. The method includes receiving the search query and parsing the search query to retrieve a search term. The search term includes a plurality of words. In the search term, a first combination of two or more of the plurality of words and a second combination of two or more of the plurality of words are indentified. The first combination and the second combination include a common term. The first combination ends with the common term and the second combination begins with the common term. The method further includes retrieving synonyms for the first combination and the second combination exist in a synonym storage and the search query is then modified to include the first combination in a logical OR relationship with the synonyms of the first combination and the second combination in a logical OR relationship with the synonyms of the second combination. The modified search query is executed against a search index or a data base.
In another embodiment, a non-transitory computer readable media having programming instructions for performing a data search through a search query is disclosed. The programming instructions, when executed by a microprocessor perform the following method steps: receiving the search query and parsing the search query to retrieve a search term. The search term includes a plurality of words. In the search term, a first combination of two or more of the plurality of words and a second combination of two or more of the plurality of words are indentified. The first combination and the second combination include a common term. The first combination ends with the common term and the second combination begins with the common term. The method further includes retrieving synonyms for the first combination and the second combination exist in a synonym storage and the search query is then modified to include the first combination in a logical OR relationship with the synonyms of the first combination and the second combination in a logical OR relationship with the synonyms of the second combination. The modified search query is executed against a data store.
In yet another embodiment, a system for performing a data search through a search query is disclosed. The system includes an application server in communication with a client computing system, the application server including a synonym processing module in communication with a synonym database. The synonym processing module is configured to retrieve synonyms for overlapping search terms in the search query. The overlapping search terms being two search terms having an overlapping common term. The system further includes a query server in communication with the application server. The query server is also in communication with a index database. A data store is included. The data store is in communication with the query server. An indexer module is also included to retrieve keywords from the data store and to store, in the index database, the keywords and location of the keywords in the data store.
Other objects, features, and advantages of the present invention will be apparent from the accompanying drawings and from the detailed description that follows below.
So that the manner in which the above recited features of the present invention can be understood in detail, a more particular description of the invention, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments. The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
An approach for modifying search queries to include synonyms for the searched terms in the search queries is described. In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are illustrated in block diagram form in order to avoid unnecessarily obscuring the present invention.
In the following description, numerous specific details are set forth to provide a more thorough understanding of the present invention. However, it will be apparent to one of skill in the art that the present invention may be practiced without one or more of these specific details. In other instances, well-known features have not been described in order to avoid obscuring the present invention.
Network 14 can be a LAN (local area network), WAN (wide area network), wireless network, point-to-point network, star network, token ring network, hub network, or other. configuration. As the most common type of network in current use is a TCP/IP (Transfer Control Protocol and Internet Protocol) network such as the global internetwork of networks often referred to as the “Internet” with a capital “I,” that will be used in many of the examples herein, but it should be understood that the networks that the present invention might use are not so limited, although TCP/IP is the currently preferred protocol.
User systems 12 might communicate with MTS 16 using TCP/IP and, at a higher network level, use other common Internet protocols to communicate, such as HTTP, FTP, AFS, WAP, etc. As an example, where HTTP is used, user system 12 might include an HTTP client commonly referred to as a “browser” for sending and receiving HTTP messages from an HTTP server at MTS 16. Such HTTP server might be implemented as the sole network interface between MTS 16 and network 14, but other techniques might be used as well or instead. In some implementations, the interface between MIS 16 and network 14 includes load sharing functionality, such as round-robin HTTP request distributors to balance loads and distribute incoming HTTP requests evenly over a plurality of servers. Preferably, each of the plurality of servers has access to the MTS's data, at least as for the users that are accessing that server.
In preferred aspects, the system shown in
One arrangement for elements of MTS 16 is shown in
Several elements in the system shown in
According to one embodiment, each user system 12 and all of its components are operator configurable using applications, such as a browser, including computer code run using a central processing unit such as an Intel Pentium processor or the like. Similarly, MTS 16 (and additional instances of MTS's, where more than one is present) and all of their components might be operator configurable using application(s) including computer code run using a central processing unit such as an Intel Pentium processor or the like, or multiple processor units. Computer code for operating and configuring MTS 16 to intercommunicate and to process web pages and other data and media content as described herein is preferably downloaded and stored on a hard disk, but the entire program code, or portions thereof, may also be stored in any other volatile or non-volatile memory medium or device as is well known, such as a ROM or RAM, or provided on any media capable of storing program code, such as a compact disk (CD) medium, digital versatile disk (DVD) medium, a floppy disk, and the like. Additionally, the entire program code, or portions thereof, may be transmitted and downloaded from a software source, e.g., over the Internet, or from another server, as is well known, or transmitted over any other conventional network connection as is well known (e.g., extranet, VPN, LAN, etc.) using any communication medium and protocols (e.g., TCP/IP, HTTP, HTTPS, Ethernet, etc.) as are well known. It will also be appreciated that computer code for implementing aspects of the present invention can be implemented in any programming language that can be executed on a server or server system such as, for example, in C, C++, HTML, Java, JavaScript, any other scripting language, such as VBScript and many other programming languages as are well known.
According to one embodiment, each MTS 16 is configured to provide web pages, forms, data and media content to user systems 12 to support the access by user systems 12 as tenants of MTS 16. As such, MTS 16 provides security mechanisms to keep each tenant's data separate unless the data is shared. If more than one MTS is used, they may be located in close proximity to one another (e.g., in a server farm located in a single building or campus), or they may be distributed at locations remote from one another (e.g., one or more servers located in city A and one or more servers located in city B). As used herein, each MTS could include one or more logically and/or physically connected servers distributed locally or across one or more geographic locations. Additionally, the term “server” is meant to include a computer system, including processing hardware and process space(s), and an associated storage system and database application (e.g., RDBMS) as is well known in the art. It should also be understood that “server system” and “server” are often used interchangeably herein. Similarly, the databases described herein can be implemented as single databases, a distributed database, a collection of distributed databases, a database with redundant online or offline backups or other redundancies, etc., and might include a distributed database or storage network and associated processing intelligence.
It should also be understood that each application server 100 may be communicably coupled to database systems, e.g., system database 106 and tenant database(s) 108, via a different network connection. For example, one server 1001 might be coupled via the Internet 14, another server 100N−1 might be coupled via a direct network link, and another server 100N might be coupled by yet a different network connection. Transfer Control Protocol and Internet Protocol (TCP/IP) are preferred protocols for communicating between servers 100 and the database system, however, it will be apparent to one skilled in the art that other transport protocols may be used to optimize the system depending on the network interconnect used.
In preferred aspects, each application server 100 is configured to handle requests for any user/organization. Because it is desirable to be able to add and remove application servers from the server pool at any time for any reason, there is preferably no server affinity for a user and/or organization to a specific application server 100. In one embodiment, therefore, an interface system (not shown) implementing a load balancing function (e.g., an F5 Big-IP load balancer) is communicably coupled between the servers 100 and the user systems 12 to distribute requests to the servers 100. In one aspect, the load balancer uses a least connections algorithm to route user requests to the servers 100. Other examples of load balancing algorithms, such as round robin and observed response time, also can be used. For example, in certain aspects, three consecutive requests from the same user could hit three different servers, and three requests from different users could hit the same server. In this manner, MTS 16 is multi-tenant, wherein MTS 16 handles storage of different objects and data across disparate users and organizations.
As an example of storage, one tenant might be a company that employs a sales force where each salesperson uses MTS 16 to manage their sales process. Thus, a user might maintain contact data, leads data, customer follow-up data, performance data, goals and progress data, etc., all applicable to that user's personal sales process (e.g., in tenant database 108). In the preferred MTS arrangement, since all of this data and the applications to access, view, modify, report, transmit, calculate, etc., can be maintained and accessed by a user system having nothing more than network access, the user can manage his or her sales efforts and cycles from any of many different user systems. For example, if a salesperson is visiting a customer and the customer has Internet access in their lobby, the salesperson can obtain critical updates as to that customer while waiting for the customer to arrive in the lobby.
While each user's sales data might be separate from other users' sales data regardless of the employers of each user, some data might be organization-wide data shared or accessible by a plurality of users or all of the sales force for a given organization that is a tenant. Thus, there might be some data structures managed by MTS 16 that are allocated at the tenant level while other data structures might be managed at the user level. Because an MTS might support multiple tenants including possible competitors, the MTS should have security protocols that keep data, applications and application use separate. Also, because many tenants will opt for access to an MTS rather than maintain their own system, redundancy, up-time and backup are more critical functions and need to be implemented in the MTS.
In addition to user-specific data and tenant-specific data, MTS 16 might also maintain system level data usable by multiple tenants or other data. Such system level data might include industry reports, news, postings, and the like that are sharable among tenants.
In certain aspects, client systems 12 communicate with application servers 100 to request and update system-level and tenant-level data from MTS 16 that may require one or more queries to database system 106 and/or database system 108. MTS 16 (e.g., an application server 100 in MTS 16) generates automatically one or more SQL statements (the SQL query) designed to access the desired information.
Each database can generally be viewed as a collection of objects, such as a set of logical tables, containing data fitted into predefined categories. A “table” is one representation of a data object, and is used herein to simplify the conceptual description of objects and custom objects according to the present invention. It should be understood that “table” and “object” may be used interchangeably herein. Each table generally contains one or more data categories logically arranged as columns or fields in a viewable schema. Each row or record of a table contains an instance of data for each category defined by the fields. For example, a CRM database may include a table that describes a customer with fields for basic contact information such as name, address, phone number, fax number, etc. Another table might describe a purchase order, including fields for information such as customer, product, sale price, date, etc. In some multi-tenant database systems, standard entity tables might be provided. For CRM database applications, such standard entities might include tables for Account, Contact, Lead and Opportunity data, each containing pre-defined fields.
System 200 further includes an application database 206. In one embodiment Application Database 206 is a relational database that provides storage for business related data. In another embodiment, Application Database 206 may be any type of storage that is capable of being queried and in response, capable of providing results to the queries. In one embodiment, Application Database 206 may be MTS 16. As explained earlier in great details, MTS 16 provides logically separate storage for business data for distinct organizations (e.g., business clients of an application hosting company). System 200 also includes an indexer 208. Indexer 208 browses Application Database 206 to retrieve keywords from database records in Application Database 206. Indexer 208 stores the retrieved keywords and their respective locations within the database records in Application Database 206 in a search index 210. Search Index 210 may be a relational database or any other type of data store that is capable of being queried by Query Servers 204. In one embodiment, Search Index 210 may be a series of one or more files stored in a file system. In one embodiment, Indexer 208 runs at pre-selected intervals to retrieve changes in the database records of Application Database 206. In one embodiment, Search Index 210 may be located in the same physical or logical database as Application Database 206. In another embodiment, Search Index 210 is maintained on a separate physical or virtual host. System 200 components may be hosted on physical hosts as well as in virtual machines running on physical hosts.
Still referring to
Synonym Database 212, in one embodiment, may reside in Application Database 206. In a multi-tenant database environment, Synonym Database 212 may include logically separate synonyms database for different customer organizations. In other embodiments, Synonym Database 212 may exist separate from Application Database 206. Cache 218 may be local to an application server or it may also be shared among other application servers in System 200. If Cache 218 is shared, it may exist on a host that is accessible to Application Servers 202. In the multi-tenant database environment, Cache 218 may include logically separate data for different client organizations. In one embodiment, Application Servers 202 (and/or other system components) are capable of identifying a relationship between the data being searched and a client organization to effectuate retrieval of data only from the logically separated databases for a particular client organization.
Still further, an application server may include a query processor 216. Query Processor 216 receives a search query from a client and parses the search query to retrieve searched keywords or phrases, or both. Cache 218 is maintained to increase efficiency of searching synonyms for the parsed keywords. Synonym Processor Module 214 performs a lookup for each of the parsed keywords to find their synonyms from Cache 218. In another embodiment, Synonym Processor Module 214 may also perform such lookup directly at Synonym Database 212. In one embodiment, Synonym Processor Module 214 may be configured to perform a synonym lookup at external synonym databases (for example, online services provided by Dictionary.com™ or other similar third parties). In one embodiment, the data retrieved from Synonym Database 212 or Cache 218 may be combined with the synonym data retrieved from an external synonym database. In one exemplary embodiment, System 200 is preconfigured for the sources of synonym data. In yet another embodiment, individual search query may specify the sources of synonym data.
Referring now to
Distributed Cache 220 is populated with the data retrieved from Synonym Database 212 or External Synonym Database 224, or both. In another embodiment, synonym data is retrieved directly from Synonym Database 212 or External Synonym Database 224, or both. In one embodiment, External Synonym Database 224 is provided by third party services. In another embodiment, External Synonym Database 224 is maintained internally within the System 200 hosting organization. In some embodiments, Synonym Database 212 may have logical separations for each client organization that uses MTS 16. Synonym Database 212 may also include global synonyms data store that is accessible and can be used for search queries from any client organizations within MTS 16. In one embodiment, global synonyms are only available to the subscribing client organizations.
After retrieving synonym data from Distributed Cache 220, the search query in User Initiated Search 222 is modified to include the retrieved synonym data. The term “query modification” as used herein means that the search query in User Initiated Search 222 is modified to include synonyms for the searched keywords or phrases. For example, suppose if the search query is in the SQL format and configured to retrieve data for the term “Ben and Jerry,” a pertinent part of the modified query may appear as “(Ben OR Benjamin) AND (Jerry OR Jerome). Of course, the assumption being that Synonym Database 212 includes the synonym “Benjamin” for the word “Ben” and the synonym “Jerome” for the word “Jerry.” In one embodiment, the modification is performed at the application server level. In another embodiment, synonym data along with the search query is sent to Query Server 204 and Query Server 204 modifies the search query before performing a data search through database indexes. Query Server 204 then performs a search according to the description provided by
Synonym data in Table 250 is typically entered manually by system users or administrators. In one embodiment, a graphical user interface is provided to facilitate entry of synonym data in Synonym Database 212. In another embodiment, synonym data may be batch uploaded from a file through an upload interface. In yet another embodiment, a synonym collector module (not shown) in System 200 may browse various synonym dictionaries to collect synonym data and populate Table 250. The synonym data in Table 250 may then be modified or updated by one or more users or administrator of System 200.
Referring back for a moment to the process of query modification as described in
In a preferred embodiment, if a searched term is not found in Key Column 252, then Synonym Database 212 does not return any synonym value for the searched term. In one exemplary embodiment, if the searched term is not found in Key Column 252, Synonym Column 254 is searched for the searched term. If a match is found for the searched term, one or more values present in the particular row in which the match is found are returned. For example (and referring to the sample data in
In one embodiment, the system may be configured to broaden or narrow synonym searches. In one example, to broaden the synonym search, search depth levels may be specified. For example, as a default, a searched term will first be searched in Key Column 252 and if a match is found, the synonyms (in Synonym Column 254) for the searched term may be returned back. However, if the synonym search is broadened to another level, each synonym value found in Synonym Column 254 is then searched in Key Column 252 and if one or more matched are found, the corresponding synonym values from Synonym Column 254 are also returned. This process may be repeated based on the configured depth of synonym searches.
In one exemplary embodiment, an intermediate query is sent to Synonym Database 212 to determine if a composite term (i.e., a multi-word term) or phrase (e.g., “jail house location” in the example) is available in Key Column 252. If an affirmative response is received, the composite term is not parsed into individual terms. If a negative response is received, the composite term is parsed into all possible combinations (e.g., into “jail house” and “house location”) and each of these combinations are searched in Key Column 252. If a match is found for a particular term, no further parsing is performed on that particular term, otherwise the process continues and the term is parsed again into other possible individual words or terms until no further parsing is possible (e.g., when the term is reduced to a word). In another embodiment, the above described process is performed even after matches are found to collect all possible synonyms for term combinations and then the retrieved synonyms are used with their corresponding search terms (using a logical OR relationship) in the modified search query.
In one embodiment, search terms for which synonyms are retrieved are assigned different weights based on their respective locations in a search query. In another embodiment, longer terms may have higher weight compared to shorter terms. Further, the system may be configured to retrieve a certain maximum number of synonyms for a term or word with a specific weight. Accordingly, more synonyms may be retrieved for search terms or words with higher weights compared to search terms or words with lower weights. Still further, the original terms may be given higher weights compared to their synonyms. In one embodiment, query servers are configured to take the respective weights of each of the searched terms in a query, while performing searches.
With the above embodiments in mind, it should be understood that the invention can employ various computer-implemented operations involving data stored in computer systems. These operations are those requiring physical manipulation of physical quantities. Any of the operations described herein that form part of the invention are useful machine operations. The invention also relates to a device or an apparatus for performing these operations. In one embodiment, the apparatus can be specially constructed for the required purpose (e.g. a special purpose machine), or the apparatus can be a general-purpose computer selectively activated or configured by a computer program stored in the computer. In particular, various general-purpose machines can be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
The embodiments of the present invention can also be defined as a machine that transforms data from one state to another state. The transformed data can be saved to storage and then manipulated by a processor. The processor thus transforms the data from one thing to another. Still further, the methods can be processed by one or more machines or processors that can be connected over a network. The machines can also be virtualized to provide physical access to storage and processing power to one or more users, servers, or clients. Thus, the virtualized system should be considered a machine that can operate as one or more general purpose machines or be configured as a special purpose machine. Each machine, or virtual representation of a machine, can transform data from one state or thing to another, and can also process data, save data to storage, display the result, or communicate the result to another machine.
The invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data, which can be thereafter be read by a computer system. Examples of the computer readable medium include hard drives, network attached storage (NAS), read-only memory, random-access memory, CD-ROMs, CD-Rs, CD-RWs, magnetic tapes and other optical and non-optical data storage devices. The computer readable medium can include computer readable tangible medium distributed over a network-coupled computer system so that the computer readable code is stored and executed in a distributed fashion.
Although the method operations were described in a specific order, it should be understood that other housekeeping operations may be performed in between operations, or operations may be adjusted so that they occur at slightly different times, or may be distributed in a system which allows the occurrence of the processing operations at various intervals associated with the processing, as long as the processing of the overlay operations are performed in the desired way.
Although the foregoing invention has been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications can be practiced within the scope of the appended claims. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.
This application claims the benefit of U.S. Provisional Application No. 61/332,092 filed on May 6, 2010.
Number | Name | Date | Kind |
---|---|---|---|
5072370 | Durdik | Dec 1991 | A |
5577188 | Zhu | Nov 1996 | A |
5608872 | Schwartz et al. | Mar 1997 | A |
5649104 | Carleton et al. | Jul 1997 | A |
5715450 | Ambrose et al. | Feb 1998 | A |
5761419 | Schwartz et al. | Jun 1998 | A |
5787437 | Potterveld et al. | Jul 1998 | A |
5794232 | Mahlum et al. | Aug 1998 | A |
5819038 | Carleton et al. | Oct 1998 | A |
5821937 | Tonelli et al. | Oct 1998 | A |
5831610 | Tonelli et al. | Nov 1998 | A |
5832500 | Burrows | Nov 1998 | A |
5873096 | Lim et al. | Feb 1999 | A |
5918159 | Fomukong et al. | Jun 1999 | A |
5941947 | Brown et al. | Aug 1999 | A |
5950190 | Yeager et al. | Sep 1999 | A |
5963953 | Cram et al. | Oct 1999 | A |
5974409 | Sanu et al. | Oct 1999 | A |
5983227 | Nazem et al. | Nov 1999 | A |
5987471 | Bodine et al. | Nov 1999 | A |
6064656 | Angal et al. | May 2000 | A |
6085191 | Fisher et al. | Jul 2000 | A |
6092083 | Brodersen et al. | Jul 2000 | A |
6112198 | Lohman et al. | Aug 2000 | A |
6161149 | Achacoso et al. | Dec 2000 | A |
6169534 | Raffel et al. | Jan 2001 | B1 |
6178425 | Brodersen et al. | Jan 2001 | B1 |
6189000 | Gwertzman et al. | Feb 2001 | B1 |
6189011 | Lim et al. | Feb 2001 | B1 |
6216133 | Masthoff | Apr 2001 | B1 |
6216135 | Brodersen et al. | Apr 2001 | B1 |
6219667 | Lu et al. | Apr 2001 | B1 |
6226641 | Hickson et al. | May 2001 | B1 |
6233617 | Rothwein et al. | May 2001 | B1 |
6233618 | Shannon | May 2001 | B1 |
6236978 | Tuzhilin | May 2001 | B1 |
6266669 | Brodersen et al. | Jul 2001 | B1 |
6288717 | Dunkle | Sep 2001 | B1 |
6295530 | Ritchie et al. | Sep 2001 | B1 |
6324568 | Diec et al. | Nov 2001 | B1 |
6324693 | Brodersen et al. | Nov 2001 | B1 |
6330560 | Harrison et al. | Dec 2001 | B1 |
6336137 | Lee et al. | Jan 2002 | B1 |
6341288 | Yach et al. | Jan 2002 | B1 |
6345288 | Reed et al. | Feb 2002 | B1 |
D454139 | Feldcamp et al. | Mar 2002 | S |
6367077 | Brodersen et al. | Apr 2002 | B1 |
6393605 | Loomans | May 2002 | B1 |
6405220 | Brodersen et al. | Jun 2002 | B1 |
6411949 | Schaffer | Jun 2002 | B1 |
6434550 | Warner et al. | Aug 2002 | B1 |
6438562 | Gupta et al. | Aug 2002 | B1 |
6446089 | Brodersen et al. | Sep 2002 | B1 |
6446109 | Gupta | Sep 2002 | B2 |
6453038 | McFarlane et al. | Sep 2002 | B1 |
6535909 | Rust | Mar 2003 | B1 |
6549908 | Loomans | Apr 2003 | B1 |
6553563 | Ambrose et al. | Apr 2003 | B2 |
6560461 | Fomukong et al. | May 2003 | B1 |
6574635 | Stauber et al. | Jun 2003 | B2 |
6577726 | Huang et al. | Jun 2003 | B1 |
6578037 | Wong et al. | Jun 2003 | B1 |
6601087 | Zhu et al. | Jul 2003 | B1 |
6604117 | Lim et al. | Aug 2003 | B2 |
6604128 | Diec et al. | Aug 2003 | B2 |
6609148 | Salo et al. | Aug 2003 | B1 |
6609150 | Lee et al. | Aug 2003 | B2 |
6621834 | Scherpbier et al. | Sep 2003 | B1 |
6654032 | Zhu et al. | Nov 2003 | B1 |
6658417 | Statukis et al. | Dec 2003 | B1 |
6665648 | Brodersen et al. | Dec 2003 | B2 |
6665655 | Warner et al. | Dec 2003 | B1 |
6684438 | Brodersen et al. | Feb 2004 | B2 |
6711565 | Subramaniam et al. | Mar 2004 | B1 |
6721765 | Ghosh et al. | Apr 2004 | B2 |
6724399 | Katchour et al. | Apr 2004 | B1 |
6728702 | Subramaniam et al. | Apr 2004 | B1 |
6728960 | Loomans et al. | Apr 2004 | B1 |
6732095 | Warshavsky et al. | May 2004 | B1 |
6732100 | Brodersen et al. | May 2004 | B1 |
6732111 | Brodersen et al. | May 2004 | B2 |
6754681 | Brodersen et al. | Jun 2004 | B2 |
6763351 | Subramaniam et al. | Jul 2004 | B1 |
6763501 | Zhu et al. | Jul 2004 | B1 |
6768904 | Kim | Jul 2004 | B2 |
6772229 | Achacoso et al. | Aug 2004 | B1 |
6782383 | Subramaniam et al. | Aug 2004 | B2 |
6804330 | Jones et al. | Oct 2004 | B1 |
6826565 | Ritchie et al. | Nov 2004 | B2 |
6826582 | Chatterjee et al. | Nov 2004 | B1 |
6826745 | Coker | Nov 2004 | B2 |
6829655 | Huang et al. | Dec 2004 | B1 |
6839608 | Liu et al. | Jan 2005 | B2 |
6842748 | Warner et al. | Jan 2005 | B1 |
6850895 | Brodersen et al. | Feb 2005 | B2 |
6850949 | Warner et al. | Feb 2005 | B2 |
6907566 | McElfresh et al. | Jun 2005 | B1 |
6944133 | Wisner et al. | Sep 2005 | B2 |
6947927 | Chaudhuri et al. | Sep 2005 | B2 |
7062502 | Kesler | Jun 2006 | B1 |
7076633 | Tormasov et al. | Jul 2006 | B2 |
7100111 | McElfresh et al. | Aug 2006 | B2 |
7152109 | Suorsa et al. | Dec 2006 | B2 |
7174483 | Worrall et al. | Feb 2007 | B2 |
7181758 | Chan | Feb 2007 | B1 |
7185192 | Kahn | Feb 2007 | B1 |
7206805 | McLaughlin, Jr. | Apr 2007 | B1 |
7206807 | Cheenath | Apr 2007 | B2 |
7209929 | Dominguez, Jr. et al. | Apr 2007 | B2 |
7249118 | Sandler et al. | Jul 2007 | B2 |
7269590 | Hull et al. | Sep 2007 | B2 |
7289976 | Kihneman et al. | Oct 2007 | B2 |
7305577 | Zhang | Dec 2007 | B2 |
7308704 | Vogel et al. | Dec 2007 | B2 |
7340411 | Cook | Mar 2008 | B2 |
7350237 | Vogel et al. | Mar 2008 | B2 |
7356482 | Frankland et al. | Apr 2008 | B2 |
7373364 | Chapman | May 2008 | B1 |
7373599 | McElfresh et al. | May 2008 | B2 |
7401094 | Kesler | Jul 2008 | B1 |
7406501 | Szeto et al. | Jul 2008 | B2 |
7412455 | Dillon | Aug 2008 | B2 |
7448079 | Tremain | Nov 2008 | B2 |
7454509 | Boulter et al. | Nov 2008 | B2 |
7484219 | Mitra | Jan 2009 | B2 |
7508789 | Chan | Mar 2009 | B2 |
7529728 | Weissman et al. | May 2009 | B2 |
7577092 | San Andres et al. | Aug 2009 | B2 |
7580975 | Cheenath | Aug 2009 | B2 |
7599935 | La Rotonda et al. | Oct 2009 | B2 |
7599953 | Galindo-Lagaria et al. | Oct 2009 | B2 |
7603331 | Tuzhilin et al. | Oct 2009 | B2 |
7620655 | Larsson et al. | Nov 2009 | B2 |
7644122 | Weyer et al. | Jan 2010 | B2 |
7661027 | Langen et al. | Feb 2010 | B2 |
7668861 | Steven | Feb 2010 | B2 |
7693820 | Larson et al. | Apr 2010 | B2 |
7698160 | Beaven et al. | Apr 2010 | B2 |
7730478 | Weissman | Jun 2010 | B2 |
7734608 | Fell et al. | Jun 2010 | B2 |
7747648 | Kraft et al. | Jun 2010 | B1 |
7769825 | Karakashian et al. | Aug 2010 | B2 |
7774366 | Fisher et al. | Aug 2010 | B2 |
7779039 | Weissman et al. | Aug 2010 | B2 |
7779475 | Jakobson et al. | Aug 2010 | B2 |
7814052 | Bezar et al. | Oct 2010 | B2 |
7814470 | Mamou et al. | Oct 2010 | B2 |
7827138 | Salmon et al. | Nov 2010 | B2 |
7827208 | Bosworth et al. | Nov 2010 | B2 |
7849401 | Elsa et al. | Dec 2010 | B2 |
7853881 | Assal et al. | Dec 2010 | B1 |
7890521 | Grushetskyy et al. | Feb 2011 | B1 |
7945653 | Zukerberg et al. | May 2011 | B2 |
8005896 | Cheah | Aug 2011 | B2 |
8014943 | Jakobson | Sep 2011 | B2 |
8015495 | Achacoso et al. | Sep 2011 | B2 |
8032297 | Jakobson | Oct 2011 | B2 |
8073850 | Hubbard et al. | Dec 2011 | B1 |
8082301 | Ahlgren et al. | Dec 2011 | B2 |
8095413 | Beaven | Jan 2012 | B1 |
8095531 | Weissman et al. | Jan 2012 | B2 |
8095594 | Beaven et al. | Jan 2012 | B2 |
8103611 | Tuzhilin et al. | Jan 2012 | B2 |
8150913 | Cheah | Apr 2012 | B2 |
8209308 | Rueben et al. | Jun 2012 | B2 |
8209333 | Hubbard et al. | Jun 2012 | B2 |
8275836 | Beaven et al. | Sep 2012 | B2 |
8457545 | Chan | Jun 2013 | B2 |
8484111 | Frankland et al. | Jul 2013 | B2 |
8490025 | Jakobson et al. | Jul 2013 | B2 |
8504945 | Jakobson et al. | Aug 2013 | B2 |
8510045 | Rueben et al. | Aug 2013 | B2 |
8510664 | Rueben et al. | Aug 2013 | B2 |
8566301 | Rueben et al. | Oct 2013 | B2 |
8646103 | Jakobson et al. | Feb 2014 | B2 |
20010023440 | Franklin et al. | Sep 2001 | A1 |
20010044791 | Richter et al. | Nov 2001 | A1 |
20020072951 | Lee et al. | Jun 2002 | A1 |
20020082892 | Raffel et al. | Jun 2002 | A1 |
20020129352 | Brodersen et al. | Sep 2002 | A1 |
20020133392 | Angel et al. | Sep 2002 | A1 |
20020140731 | Subramaniam et al. | Oct 2002 | A1 |
20020143997 | Huang et al. | Oct 2002 | A1 |
20020162090 | Parnell et al. | Oct 2002 | A1 |
20020165742 | Robbins | Nov 2002 | A1 |
20030004971 | Gong | Jan 2003 | A1 |
20030018705 | Chen et al. | Jan 2003 | A1 |
20030018830 | Chen et al. | Jan 2003 | A1 |
20030066031 | Laane et al. | Apr 2003 | A1 |
20030066032 | Ramachandran et al. | Apr 2003 | A1 |
20030069936 | Warner et al. | Apr 2003 | A1 |
20030070000 | Coker et al. | Apr 2003 | A1 |
20030070004 | Mukundan et al. | Apr 2003 | A1 |
20030070005 | Mukundan et al. | Apr 2003 | A1 |
20030074418 | Coker et al. | Apr 2003 | A1 |
20030120675 | Stauber et al. | Jun 2003 | A1 |
20030151633 | George et al. | Aug 2003 | A1 |
20030159136 | Huang et al. | Aug 2003 | A1 |
20030187921 | Diec et al. | Oct 2003 | A1 |
20030189600 | Gune et al. | Oct 2003 | A1 |
20030204427 | Gune et al. | Oct 2003 | A1 |
20030206192 | Chen et al. | Nov 2003 | A1 |
20030225730 | Warner et al. | Dec 2003 | A1 |
20040001092 | Rothwein et al. | Jan 2004 | A1 |
20040010489 | Rio et al. | Jan 2004 | A1 |
20040015578 | Karakashian et al. | Jan 2004 | A1 |
20040015981 | Coker et al. | Jan 2004 | A1 |
20040027388 | Berg et al. | Feb 2004 | A1 |
20040044656 | Cheenath | Mar 2004 | A1 |
20040045004 | Cheenath | Mar 2004 | A1 |
20040111410 | Burgoon et al. | Jun 2004 | A1 |
20040122656 | Abir | Jun 2004 | A1 |
20040128001 | Levin et al. | Jul 2004 | A1 |
20040186860 | Lee et al. | Sep 2004 | A1 |
20040193510 | Catahan et al. | Sep 2004 | A1 |
20040199489 | Barnes-Leon et al. | Oct 2004 | A1 |
20040199536 | Barnes Leon et al. | Oct 2004 | A1 |
20040199543 | Braud et al. | Oct 2004 | A1 |
20040205079 | Azzam | Oct 2004 | A1 |
20040220952 | Cheenath | Nov 2004 | A1 |
20040249854 | Barnes-Leon et al. | Dec 2004 | A1 |
20040260534 | Pak et al. | Dec 2004 | A1 |
20040260659 | Chan et al. | Dec 2004 | A1 |
20040268299 | Lei et al. | Dec 2004 | A1 |
20050050555 | Exley et al. | Mar 2005 | A1 |
20050091098 | Brodersen et al. | Apr 2005 | A1 |
20050283478 | Choi et al. | Dec 2005 | A1 |
20060095960 | Arregoces et al. | May 2006 | A1 |
20060100912 | Kumar et al. | May 2006 | A1 |
20060136382 | Dettinger et al. | Jun 2006 | A1 |
20060265391 | Posner et al. | Nov 2006 | A1 |
20070022109 | Imielinski et al. | Jan 2007 | A1 |
20070078705 | Abels et al. | Apr 2007 | A1 |
20070088741 | Brooks et al. | Apr 2007 | A1 |
20070124276 | Weissman et al. | May 2007 | A1 |
20070130130 | Chan et al. | Jun 2007 | A1 |
20070130137 | Oliver et al. | Jun 2007 | A1 |
20070150546 | Karakashian et al. | Jun 2007 | A1 |
20070226640 | Holbrook et al. | Sep 2007 | A1 |
20080010243 | Weissman et al. | Jan 2008 | A1 |
20080082540 | Weissman et al. | Apr 2008 | A1 |
20080082572 | Ballard et al. | Apr 2008 | A1 |
20080082986 | Cheenath et al. | Apr 2008 | A1 |
20080086358 | Doshi et al. | Apr 2008 | A1 |
20080086447 | Weissman et al. | Apr 2008 | A1 |
20080086479 | Fry et al. | Apr 2008 | A1 |
20080086482 | Weissman et al. | Apr 2008 | A1 |
20080086514 | Weissman et al. | Apr 2008 | A1 |
20080086567 | Langen et al. | Apr 2008 | A1 |
20080086735 | Cheenath et al. | Apr 2008 | A1 |
20080162544 | Weissman et al. | Jul 2008 | A1 |
20080201701 | Hofhansel et al. | Aug 2008 | A1 |
20080215560 | Bell et al. | Sep 2008 | A1 |
20080249972 | Dillon | Oct 2008 | A1 |
20080270354 | Weissman et al. | Oct 2008 | A1 |
20080270987 | Weissman et al. | Oct 2008 | A1 |
20090030906 | Doshi et al. | Jan 2009 | A1 |
20090049065 | Weissman et al. | Feb 2009 | A1 |
20090049101 | Weissman et al. | Feb 2009 | A1 |
20090049102 | Weissman et al. | Feb 2009 | A1 |
20090049288 | Weissman et al. | Feb 2009 | A1 |
20090063415 | Chatfield et al. | Mar 2009 | A1 |
20090100342 | Jakobson | Apr 2009 | A1 |
20090171907 | Radovanovic | Jul 2009 | A1 |
20090177744 | Marlow et al. | Jul 2009 | A1 |
20090276395 | Weissman et al. | Nov 2009 | A1 |
20090276405 | Weissman et al. | Nov 2009 | A1 |
20090282045 | Hsieh et al. | Nov 2009 | A1 |
20090319529 | Bartlett et al. | Dec 2009 | A1 |
20100191719 | Weissman et al. | Jul 2010 | A1 |
20100205216 | Durdik et al. | Aug 2010 | A1 |
20100211619 | Weissman et al. | Aug 2010 | A1 |
20100223284 | Brooks et al. | Sep 2010 | A1 |
20100235837 | Weissman et al. | Sep 2010 | A1 |
20100274779 | Weissman et al. | Oct 2010 | A1 |
20110066620 | Redfern et al. | Mar 2011 | A1 |
20110145247 | Norris et al. | Jun 2011 | A1 |
20120233137 | Jakobson et al. | Sep 2012 | A1 |
20120290407 | Hubbard et al. | Nov 2012 | A1 |
20130218948 | Jakobson | Aug 2013 | A1 |
20130218949 | Jakobson | Aug 2013 | A1 |
20130218966 | Jakobson | Aug 2013 | A1 |
Number | Date | Country |
---|---|---|
WO2004059420 | Jul 2004 | WO |
Entry |
---|
[online]; [published on Oct. 17, 2008]; [retrieved on Feb. 26, 2010]; retrieved from http://en.wikipedia.org/wiki/Push—technology. |
[online]; [published on Oct. 16, 2008]; [retrieved on Feb. 26, 2010]; retrieved from http://en.wikipedia.org/wiki/Customer13 Relationship—Management. |
[online]; [published on Apr. 22, 2008]; [retrieved on Feb. 26, 2010]; retrieved from http://en.wikipedia.org/wiki/Flat—file—database. |
[online]; [published on Apr. 25, 2008]; [retrieved on Feb. 26, 2010]; retrieved from http://en.wikipedia.org/wiki/Relational—database. |
First named inventor: Yancey, Scott, U.S. Appl. No. 12/636,658, filed Dec. 11, 2009. |
First named inventor: Yancey, Scott, U.S. Appl. No. 12/636,675, filed Dec. 11, 2009. |
First named inventor: Doshi, Kedar, U.S. Appl. No. 12/167,991, filed Jul. 3, 2008. |
First named inventor: Bezar, Eric, U.S. Appl. No. 12/569,603, filed Sep. 2, 2010. |
First named inventor: Yancey, Scott, U.S. Appl. No. 12/132,409, filed Jun. 3, 2008. |
First named inventor: Durdik, Paul, U.S. Appl. No. 12/549,349, filed Aug. 27, 2009. |
Lee et al: “Composition of executable business process models by combining business rules and process flows”, Expert Systems With Application, Oxford, GB, vol. 33, No. 1, Dec. 22, 2006, pp. 221-229. |
Mietzer et al: “Combining Different Multi-tenancy Patterns in Service Oriented Applications”, IEE International Enterprise Distributed Object Computing Conference, NJ, USA, Sep. 1, 2009, pp. 131-140. |
Wang et al: “Integrated Constraint Violation Handling for Dynamic Services Composition”, IEE International Conference on Services Computing, NJ, USA, Sep. 21, 2009, pp. 168-175. |
Wermelinger et al: “Using coordination contracts for flexible adaptation to changing business rules”, Proceedings of the Sixth International Workshop on Software Evolution, NJ, USA, Sep. 1, 2003, pp. 115-120. |
Wang et al: “A Study and Performance Evaluation of the Multi-Tenant Data Tier Design Patterns for Service Oriented Computing”, IEE International Conference on E-Business Engineering, NJ, USA, Oct. 22, 2008, pp. 94-101. |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration. International Application Number: PCT/US2010/050021. International Filing Date: Sep. 23, 2010. |
First named inventor: Yancey, Scott, U.S. Appl. No. 12/197,979, filed Aug. 25, 2008. |
First named inventor: Calahan, Patrick, U.S. Appl. No. 12/954,556, filed Nov. 24, 2010. |
First named inventor: Varadharajan, Arunkumaran, U.S. Appl. No. 12/909,820, filed Oct. 21, 2010. |
First named inventor: Pin, Oliver, U.S. Appl. No. 12/895,833, filed Sep. 30, 2010. |
First named inventor: Tanaka, Jay, U.S. Appl. No. 12/831,209, filed Jul. 6, 2010. |
First named inventor: Tanaka, Jay, U.S. Appl. No. 12/831,196, filed Jul. 6, 2010. |
First named inventor: Williams, Alexis, U.S. Appl. No. 13/028,236, filed Feb. 16, 2011. |
“Google Plus Users”, Google+Ripples, Oct. 31, 2011 [retrieved on Feb. 21, 2012 from Internet at http://www.googleplusers.com/google-ripples.html], 3 pages. |
Number | Date | Country | |
---|---|---|---|
20110276580 A1 | Nov 2011 | US |
Number | Date | Country | |
---|---|---|---|
61332092 | May 2010 | US |