A database query user interface combines the user convenience of simple text searching with the expressive refinements of powerful query language. The database query user interface includes a query text string input from a user including one or more terms of a chunk expression language format. The database query user interface further includes a syntactical prompt for constructing a multi-element chunk expression language database query that is syntactically correct and complete and includes the text string input from the user. For example, the syntactical prompt is selected from the database based upon a weighted analysis of database information relating to database elements included in the text string input from the user. A database query formed according to the present user interface may then be persisted or stored as a database query object.
|
37. A method, comprising:
under control of one more processors configured with specific executable instructions to perform acts comprising:
displaying a first syntactical prompt to construct an initial portion of a database query in a chunk expression language format, the database query including a query construction record identifying user actions that produced the database query;
displaying a second syntactical prompt to construct a second portion of the database query in the chunk expression language format, the second portion comprising a multi-element chunk expression language syntactic group that completes a syntactically correct expression for the database query, the second syntactical prompt including a text string corresponding to information in the database, the text string selected from the database based upon a weighted analysis of database information relating to database elements included in at least a portion of the database query, the weighted analysis of database information including a result count factor that increases weight to information that increases results up to a maximum count and decreases the weight to the information for a portion of the results that exceed the maximum count;
forming the database query in a chunk expression language such that the database query is syntactically correct regardless of whether the database query yields no results;
storing the database query in a persistent database query object; and
storing, in the persistent database query object, an exception list of exceptions to the database query, the exception list specified by a user.
1. A database query user interface for forming a database query for a database, comprising:
a first syntactical prompt, provided by a processor, for constructing an initial portion of a database query in a chunk expression language format, the database query including a query construction record identifying user actions that produced the database query;
a second syntactical prompt, provided by the processor, for constructing a second portion of the database query in the chunk expression language format, the second portion comprising a multi-element chunk expression language syntactic group that completes a syntactically correct expression for the database query, the second syntactical prompt including a text string corresponding to information in the database, the text string selected from the database based upon a weighted analysis of database information relating to database elements included in at least a portion of the database query, the weighted analysis of database information including a result count factor that increases weight to information that increases results up to a maximum count and decreases the weight to the information for a portion of the results that exceed the maximum count, the chunk expression language resulting in the database query being syntactically correct, the chunk expression language enabling creation of an empty query that when executed at a first time yields no results but when executed at a second time yields one or more results;
a list of exceptions to the database query; and
a query status user interface, provided by the processor, to indicate whether the database query is valid or invalid.
25. A computer readable medium storing software instructions while excluding carrier signals, the software instructions executable by one or more processors to perform acts comprising:
displaying a first syntactical prompt to construct an initial portion of a database query in a chunk expression language format, the database query including a query construction record identifying user actions that produced the database query;
displaying a second syntactical prompt to construct a second portion of the database query in the chunk expression language format, the second portion comprising a multi-element chunk expression language syntactic group that completes a syntactically correct expression for the database query, the second syntactical prompt including a text string corresponding to information in the database, the text string selected from the database based upon a weighted analysis of database information relating to database elements included in at least a portion of the database query, the weighted analysis of database information including a result count factor that increases weight to information that increases results up to a maximum count and decreases the weight to the information for a portion of the results that exceed the maximum count;
forming the database query in the chunk expression language based on the first syntactical prompt and the second syntactical prompt, the chunk expression language resulting in the database query being syntactically correct, the chunk expression language enabling creation of an empty query that when executed at a first time yields no results but when executed at a second time yields results;
storing the database query in a persistent database query object; and
storing, in the persistent database query object, an exception list of exceptions to the database query, the exception list specified by a user.
12. A system comprising one or more processors and a memory device storing instructions that are executable by the one or more processors to display a database query user interface for forming a database query for a database, the database query user interface comprising:
a text string input received from a user, by a processor, the text string input including one or more terms of a chunk expression language;
a first syntactical prompt, provided by the processor, for constructing a database query using multiple elements of the chunk expression language, the database query formed such that the database query is syntactically correct and complete, the database query including the text string input, the database query including a query construction record identifying user actions that produced the database query;
a second syntactical prompt, provided by the processor, for constructing a second portion of the database query in the chunk expression language format, the second portion comprising a multi-element chunk expression language syntactic group that completes a syntactically correct expression for the database query, the second syntactical prompt including a text string corresponding to information in the database, the text string selected from the database based upon a weighted analysis of database information relating to database elements included in at least a portion of the database query, the weighted analysis of database information including a result count factor that increases weight to information that increases results up to a maximum count and decreases the weight to the information for a portion of the results that exceed the maximum count, the chunk expression language resulting in the database query being syntactically correct, the chunk expression language enabling creation of an empty query that when executed at a first time yields no results but when executed at a second time yields one or more results;
a user-specified list of exceptions to the database query; and
a query status, provided by the processor, that indicates a status of the database query.
2. The user interface of
3. The user interface of
4. The user interface of
5. The user interface of
6. The user interface of
7. The user interface of
8. The user interface of
9. The user interface of
10. The user interface of
11. The user interface of
13. The system of
14. The system of
15. The system of
16. The system of
17. The system of
18. The system of
19. The system of
20. The system of
21. The system of
the database query object includes a data structure having an exception list of exceptions to the database query, the exception list specified by the user, and
the user interface to automatically generate a revised database query in the chunk expression language format, the query taking into account the exceptions in the exception list.
22. The system of
23. The system of
24. The system of
26. The computer readable medium of
27. The computer readable medium of
28. The computer readable medium of
29. The computer readable medium of
30. The computer readable medium of
31. The computer readable medium of
32. The computer readable medium of
33. The computer readable medium of
displaying a status of the database query, the status indicating whether the database query is valid or invalid.
34. The computer readable medium of
35. The computer readable medium of
36. The computer readable medium of
38. The method of
39. The method of
40. The method of
41. The method of
42. The method of
43. The method of
44. The method of
45. The method of
46. The method of
47. The method of
|
The present invention relates to user interfaces for building database queries and, in particular, to a database query user interface that includes syntactically correct prompting and persistent database query objects.
A database can hold a tremendous amount of information. At any given time, a user will only want to see a subset of that information. Users select that subset by defining a query, which is a piece of text written in a query specification language, such as SQL. But because query specification languages are complex, they are typically not appropriate for end users. For end users, there are simpler languages such as chunk expression languages or simple full-text searching. Some simplified query languages are not expressive enough for users to develop queries with adequate refinements to access information from a database. Simplified query languages that are expressive enough are often as difficult to learn as a query specification language, and so are inappropriate for end users. Text searches are too inaccurate and return too many unrelated results to be useful.
Accordingly, the present invention provides a database query user interface that that combines the user convenience of simple text searching with the expressive refinements of powerful query languages. In one implementation, a database query user interface includes a query text string input from a user. The query text string has one or more terms of a chunk expression language format. A chunk expression language format is a pseudo-natural language (e.g., English-like, or like any other human language) that can be easily parsed by a computer into a formal query specification language, such as SQL. Simple chunk expressions were developed as early as 1986 in the HyperCard project of Apple Corporation. The SK8 authoring tool, also developed by Apple Corporation, provided a complete chunk expression language by 1988.
The database query user interface of the present invention further includes a syntactical prompt for constructing a multi-element chunk expression language database query that is syntactically correct and complete and includes the text string input from the user. For example, the syntactical prompt is selected from the database based upon a weighted analysis of database information relating to database elements included in the text string input from the user.
A database query formed according to the present user interface may then be persisted or stored as a database query object. Such an object allows a query to be refined, such as by a user adding or deleting items in a set of results returned by the query. Such additions or deletions, which are referred to as exceptions, may be stored with the query as a data structure. In some implementations, a revised database query in the chunk expression language format can be generated automatically to incorporate exceptions in the exception list, thereby refining the query and reducing resource requirements for maintaining and implementing the separate exceptions. The present invention provides, therefore, a database query user interface that combines the user convenience of conventional simple search languages with the expressiveness and refinements of powerful query specification languages.
Additional objects and advantages of the present invention will be apparent from the detailed description of the preferred embodiment thereof, which proceeds with reference to the accompanying drawings.
A conventional database system or database includes a collection of tables with record entries. Queries of the database are typically made using a query specification language, sometimes referred to as a data manipulation language, such as SQL. In addition, a full-text search engine can find records that contain text strings. A variety of commercially available databases are available, including Microsoft SQL available from Microsoft Corporation. The term database is used herein to refer generally to any “property store” that includes objects or files with searchable properties.
As is known in the art, a chunk expression language format is a pseudo-natural language (e.g., English-like) that can be easily parsed by a computer into a formal query specification language, such as SQL. A sample chunk expression might be:
AND SUBJECT LIKE ‘%patent%’
In general, a chunk expression might take the form of:
User interface 200 automatically prompts a user for a syntactically correct word from a set of all possible choices. This prevents the user from making syntax errors while beginning to enter chunk expressions. For example, if the user begins a chunk expression entry 202 by entering “show all”, the user interface automatically determines that an object is the syntactically correct next entry. As a result, user interface 200 presents the user with a list 204, such as a drop-down listing as illustrated of all syntactically correct objects (e.g., email, files, music, pictures, items).
Such a simple single-part-of-speech completion is not uncommon, and can be found as part of the Intellisense™ technology in Microsoft Visual Studio .NET, for example, available from Microsoft Corporation. User interface 200 illustrates, however, only a first syntactical prompting step in aiding a user with construction of a query according to the present invention.
Based upon an initial chunk expression 302 formed from a user interface 200, for example, user interface 300 automatically prompts a user with a list 304 of complete, readable syntactically correct expressions to choose from. For example, based upon an initial chunk expression 302 of “show all email,” the user interface automatically provides list 304 of complete, readable syntactically correct expressions such as: whose sender is ‘John smith,’ whose subject contains ‘xyzcorp,’ whose date is ‘today,’ or whose status is ‘unread.’
As a result, user interface 300 operates as a completion routine that suggests complete, readable expressions so that the user is not left with a query having a syntactically invalid expression. For example, a system with conventional single word completion might complete “show all email whose” with a choice of “sender”, “subject”, “date”, etc. If the user selects one of these words alone, the resulting chunk expression will be the phrase “show all email whose sender”, which is not syntactically valid if evaluated or executed. In the user interface of
One benefit of providing prompting with a complete, valid query phrase is that a user who selects the prompting is always left with a completely valid query phrase that upon evaluation will give a valid result. Another benefit is that the user is able to read an entire phrase and can better understand what the different choices mean. As a result, the user can readily modify a phrase to further adapt it to indicate the desired query.
The terms in the syntactical prompts are based upon information in the database or information about prior database activities. In some implementations, the information is weighted to make the prompted completions more intuitive, as described below in greater detail. In contrast, conventional database systems rely at most on a simple pre-made list of possible completion words.
Once a query has been selected, it can be edited by a user to make a new query. Chunk expression languages lend themselves to user modification. A user can easily understand that if “show all email whose sender=‘john’” produces email from John, then changing the word “john” to “sean” will produce email from Sean. Users can make these modifications even if they do not know the syntax of the language well enough to correctly write the expression themselves from a blank line.
Conventional database query systems would be unable to provide a list of terms taken from the database. Instead, a conventional database query system might insert a placeholder like “sender is <person-name>”, which is not syntactically valid.
Another aspect of the present invention is that queries such as those described with reference to
Persistent query object data structure 800 allows queries to be constructed once and easily reused, thereby facilitating re-use of the query to enable users to repeat common queries. Such persisted queries may be listed by their chunk expression language format, or any other distinguishing characteristic, and activated from the user interface listing. In addition, such re-use of the queries allows them to be refined to provide improved query results for the user.
As one implementation, query status user interface 900 can be rendered with a green color to indicate that the selected query is valid (i.e., the results shown are the same results that would be generated if the query were executed again immediately), a yellow color to indicate that the selected query is out of date (i.e., the results would be different if the query would be executed at this moment), a red color to indicate that the query is invalid (i.e., the query has not been executed), or a flashing yellow color to indicate that the selected continuously updating (i.e., the current query results will be changed whenever the database changes).
Query objects can also help users distinguish between modifying an existing query and specifying a new one. As an object, a query can be represented on the screen with a unique name, a history, query text, etc., thereby allowing for a clear distinction between when the property of a query is being changed versus when a new query is being defined.
An exception list, such as an exception list 810 included in data structure 800, is a listing of one or more modifications (e.g., additions or deletions) a user makes to the results of a query. These modifications may be persisted as exception list 810. It will be appreciated that in the exception list it is the query results that is modified by the user rather than the query specification itself.
As an example, a user might be constructing a play list of music files. The user might start by specifying a query for music, such as “show all music whose decade=‘80s’ and whose genre=‘modern rock’ and whose ranking>4”. This might produce an initial list of 200 songs, for example. The user might then add a few songs that do not match the query and remove a few songs that match but that the user personally dislikes.
The exception list, separate from the query but persisted with it, allows a user to have direct and simple manipulation of query results without having to define a valid query to achieve the modified results. The exception list is a property of the query that is separate from the query specification. A user can change one without affecting the other.
Some prior systems will force a query with exceptions to be valid by adding or removing properties from the added or removed items to make them comply with the query. For example, adding or removing a picture from a “my favorite pictures” query will add or remove the “favorite” property of those pictures. While this is sometimes desirable, it often leads to unexpected behavior. For instance, in such a system adding a song from the 90's to a list of query results from the 70's would cause the son to be retagged as being from the 70's. With more complicated queries, the confusion is even greater. Because of this increased complexity, the user interfaces for these systems require excessive additional prompting, confirming, and explaining.
In some other prior systems, adding or removing an item from the query results invalidates the query and turns it into a simple list of items. The problem with this approach is that the user is forced to construct a correct query before any modifications are made. If the query is later modified, the user's earlier query result modifications are lost. For instance, a user might search for songs between 1970 and 1980, then remove a few songs the user dislikes. The user then may notice that some desired songs are missing because they are actually from the late 60's. If the user changes the query then to show songs from 1965 to 1980, all of the songs removed from the prior query results will be reinserted again.
Implementing the exception list as a property of the query separate from the query specification allows the exception list to be changed without affecting the query specification. Likewise, the query specification can be changed without affecting the exception list.
The issue of exceptions can be of particular significance in systems where the user expects to have the ability to directly manipulate the results of a query. An example is a file system that is based upon a database structure. Most users of a file system are accustomed to “drag and drop operations” and would be intolerant of conventional database system restriction to modifications. To accommodate such users, the exception list can be modified with direct user manipulations (e.g., “drag and drop”) of objects. Direct user manipulations are recorded as changes to the query exception list.
Representing queries as objects also allows for support of so-called “empty queries”. An empty query is a query that exists despite having no results. For example, a user can create a query for airfares from Seattle to China for under $600. This query might have no results the first time it is run, but the user still may want to save it to run in the future, or on a regular basis. If queries are not objects but are just query results, this is not possible.
Query objects also allow for queries that have no query specification, but rather are composed only of one or more exceptions or exception lists. For instance, a user could make a query called “stuff I need to complete for manager” that has no search string at all. The user could then add any number of items (e.g., documents) as exceptions to that query. The only things that this query would return are those items that are explicitly added. This allows for hand-made lists to be treated with the exact same code and user interface as queries. It also makes for an easy migration path from non-query based systems (such as the traditional folder hierarchy of file management systems) to query-based systems.
In step 1102 a user specifies or modifies a query with exceptions.
In step 1104 objects that are added or removed as exceptions are inspected to determine whether they have one or more common properties.
In decision block 1106 an inquiry is made as to whether the exception objects have one or more common properties. If the exception objects have one or more common properties, decision block 1106 proceeds to step 1108. If not, decision block proceeds to termination block 1110 and the exception objects are maintained as an exception list.
In step 1108 the query specification is rewritten to include reference to the common properties, and the exception list is recalculated. As a result, the query will generate the same results but without the system overhead of the exceptions. The query will be more accurate and thus more appropriate for reuse in the future.
For example, a user may want a list of work emails from a manager. The user gets a list of email from Manager, but notices that personal emails are included in the initial list. The user might not know how to write a more complicated query that will just show the work emails, so the selects the personal emails from the list and deletes them.
In accordance with automated query re-write method 1100, the user interface then inspects those exceptions and produces an auto-rewrite user interface affordance or indication 1200 (
This type of prompting is meant to be non-invasive. It is not necessary for the user to respond to it. If curious about the re-write, the user can move the mouse over the auto-rewrite user interface affordance 1200, for example, to see the suggested rewrite 1300 (
In this case, the user interface noticed that all of the removed emails were also sent to Mrs. Manager, Manager's wife. The ability to inspect the query in a lightweight way is made possible by the highly readable nature of the chunk expression language. This type of preview allows the user to prevent inadvertent coincidences from being incorporated into the query specification. For example, when making a playlist, the user might remove a several disliked songs. All of the songs might happen to be from a particular record label, and the user interface might suggest the record label characteristics as a rewrite. In case of inadvertent coincidence the user would not accept the rewrite.
In addition, automated query re-write method 1100 can optionally effect changes to the underlying properties of the objects. For instance, when pictures are discarded from a “favorites” list, the user interface could suggest removing the “favorites” property from those objects. Again, this could be done in a light-weight, non-intrusive fashion.
In contrast to the grammatical query autocomplete (GQA) feature, a conventional prior system with “John XYZCorp” entered as a query would perform a full-text search of the entire database for items that contain either “john” or “XYZCorp”, or perhaps contain both “john” and “XYZCorp”. In either case, the full-text search would likely return significantly more results than the user needs or wants.
The problem with conventional prior default query is that while the user has a definite goal in mind (such as “I want the email from john about xyxcorp” or “I want that picture of john taken at xyzcorp”), the user often does not know how to correctly specify such an expression to the computer. The grammatical query autocomplete (GQA) feature leverages the readability of the chunk expression language to provide the user with a list of valid, likely completions.
In step 1602, text fragments of the partial query are analyzed and each individual word is classified into an object type. For example, the text fragments are first checked against the representation of the chunk expression grammar (basically a dictionary look-up). The text fragments are then checked via a full-text search against records in the database. If the word occurs in a particular field in a database table, the object type will be determined from that table. In each of these, the user interface can match whole words or partial words, and there could be several possible object types for each word. For instance, “john pictures” could mean “show pictures of john” or “show email from john with the word pictures in the subject.” The term “picture” could be an object or just a text string. Each choice is given a probability rating. There could be several rating schemes, and grammatical query autocomplete method 1600 does not depend upon any particular one. one implementation of a weighting scheme is described below.
In step 1604, the computed object types are compared with a list of all syntactically valid expressions that use those parts of speech. In the “john xyzcorp” example, the user interface will classify “john” as both a text string and as a possible value for the “name” field of a person record. “xyzcorp” is a text string, a possible value for the “name” field of a place record, and a possible value for the “subject” field of an email record. Based on this, the user interface will look for syntactically correct statements that incorporate a person and a place, a person and an email, etc. All of these possibilities are then also assigned weights, as in step 1602.
In step 1606, the text string is compared to other text strings that have been passed in for autocompletion using simple string matching. For example, the user might type “john xyzcorp” and then select the “show email from john about xyzcorp” completion. If the user later starts typing “jo”, then the “jo” will match the previously entered “john xyzcorp” string, and the user interface will add the previously chosen completion “show email from john about xyzcorp” to the list of matches. The list of matches is then combined with the results of step 1604. Since many people do the same queries over and over again, this step reduces most common queries to just three or four key strokes.
In step 1608, the final sorted, weighted list is then displayed to the user.
In step 1702, the user interface remembers when a proposed completion is selected by creating an association object, which shows that the prompt and the completion are related. The user interface then uses these associations to increase the weighting of that completion in the future. If the user chooses “john” from a list of “People”, John will be weighted more towards the top of the list in the future.
Moreover, the association object can handle the deep associations in complex completions. For example, if a user enters “john disney”, the completion “show pictures where subject contains ‘john smith’ and location is ‘disneyland’” might be low on the list. Once the user selects it, however, the user interface will not only associate “john disney” with “show pictures where subject contains ‘john smith’ and location is ‘disneyland’”, the user interface will also associate “john” with the person named ‘john smith’ and “disney” with the place named ‘disneyland’. It will associate both john and disneyland with photos, and it will even associate phrases consisting of a person and a place as being likely about photos. In the future if the user types something like “dave disney” or “mike grand canyon”, completions that contain pictures will be given more weight.
In step 1704 the number of results is taken into account when weighting a result. In general, results might follow a curve like a Bell curve, where “more results” becomes better up to a point, then there are so many results that it actually becomes not specific enough. For instance, if the user types “b mail”, the user interface might suggest completions of “show email whose subject contains ‘b’”, “show email whose sender is Brian”, and “show email whose sender is Benefits”. All of these are valid completions, but the first might return 5000 items, the second might return 90 items, and the third might return 1 item. The result count metric would ensure that the second option “show email whose sender is Brian” comes to the top. This solves the common autocomplete problem of the user interface always suggesting the incorrect Dave, John, or Matt.
Because this result count weighting is done in context, it appears very intelligent. For instance, the user might have more email from manager John Smith than pictures of John Smith, and a lot of pictures of friend John Jones but relatively little email from John Jones. When the user interface completes “john pictures”, “show pictures whose subject is John Jones” will be the first choice, but for “john email”, “show email whose sender is ‘john smith’” will be first.
Different implementations may contain different selections, object types, properties, and comparators than those described hereinabove. The present invention is not limited to any particular implementation and applies to any database format, query language specification, etc.
In accordance with the practices of persons skilled in the art of computer programming, the present invention is described above with reference to acts and symbolic representations of operations that are performed by various computer systems and devices. Such acts and operations are sometimes referred to as being computer-executed and may be associated with the operating system or the application program as appropriate. It will be appreciated that the acts and symbolically represented operations include the manipulation by a central processing unit (CPU) of electrical signals representing data bits, which causes a resulting transformation or reduction of the electrical signal representation, and the maintenance of data bits at memory locations in a memory system, such as a computer readable medium, to thereby reconfigure or otherwise alter the computer system operation, as well as other processing of signals. The memory locations where data bits are maintained are physical locations that have particular electrical, magnetic, or optical properties corresponding to the data bits.
Having described and illustrated the principles of our invention with reference to an illustrated embodiment, it will be recognized that the illustrated embodiment can be modified in arrangement and detail without departing from such principles. In view of the many possible embodiments to which the principles of our invention may be applied, it should be recognized that the detailed embodiments are illustrative only and should not be taken as limiting the scope of our invention. Rather, we claim as our invention all such embodiments as may come within the scope and spirit of the following claims and equivalents thereto.
Marcjan, Cezary, Turski, Andrzej, Vronay, David P., Kott, Ryszard
Patent | Priority | Assignee | Title |
10394894, | Nov 28 2012 | BloomReach Inc. | Search with autosuggest and refinements |
10481766, | Feb 10 2017 | Microsoft Technology Licensing, LLC | Interfaces and methods for generating and applying actionable task structures |
10514827, | Feb 10 2017 | Microsoft Technology Licensing, LLC | Resequencing actionable task structures for transforming data |
10521448, | Feb 10 2017 | Microsoft Technology Licensing, LLC | Application of actionable task structures to disparate data sets for transforming data in the disparate data sets |
10528523, | May 31 2017 | International Business Machines Corporation | Validation of search query in data analysis system |
10776366, | May 25 2016 | Alation Inc. | Computer-implemented method and system for writing and performing a data query |
11468072, | May 25 2016 | ALATION INC | Computer-implemented method and system for writing and performing a data query |
8812496, | Oct 24 2011 | Xerox Corporation | Relevant persons identification leveraging both textual data and social context |
9348870, | Feb 06 2014 | International Business Machines Corporation | Searching content managed by a search engine using relational database type queries |
9384244, | Nov 28 2012 | BLOOMREACH INC | Search with autosuggest and refinements |
9501529, | Feb 06 2014 | International Business Machines Corporation | Searching content managed by a search engine using relational database type queries |
Patent | Priority | Assignee | Title |
4829423, | Jan 28 1983 | Texas Instruments Incorporated | Menu-based natural language understanding system |
5454106, | May 17 1993 | International Business Machines Corporation | Database retrieval system using natural language for presenting understood components of an ambiguous query on a user interface |
5584024, | Mar 24 1994 | SPEEDWARE LTEE LTD | Interactive database query system and method for prohibiting the selection of semantically incorrect query parameters |
5619688, | Sep 02 1993 | Microsoft Technology Licensing, LLC | Method and system for constructing database queries using a field selection grid |
5778357, | Jun 11 1991 | LOGICAL INFORMATION MACHINES, INC | Market information machine |
5787275, | May 31 1995 | International Business Machines Corporation | Identifying multiple level class relationships in an object oriented system using icons and lines to represent class relationships |
5802512, | Mar 12 1996 | Oracle International Corporation | Storage, replay and error detection of user-defined queries |
6014669, | Oct 01 1997 | Oracle America, Inc | Highly-available distributed cluster configuration database |
6016488, | Jan 22 1997 | Microsoft Technology Licensing, LLC | Method and system for constructing queries |
6078916, | Aug 01 1997 | IAC SEARCH & MEDIA, INC | Method for organizing information |
6338055, | Dec 07 1998 | INNOVATION TECHNOLOGY GROUP, INC | Real-time query optimization in a decision support system |
6356887, | Jun 28 1999 | Microsoft Technology Licensing, LLC | Auto-parameterization of database queries |
6430563, | Oct 07 1997 | SAP SE | Integrated knowledge provider with logical hyperlinks |
6477534, | May 20 1998 | Lucent Technologies, Inc. | Method and system for generating a statistical summary of a database using a join synopsis |
6487553, | Jan 05 2000 | LinkedIn Corporation | Method for reducing search results by manually or automatically excluding previously presented search results |
6564213, | Apr 18 2000 | A9 COM, INC | Search query autocompletion |
20010021929, | |||
20020069086, | |||
20030088554, | |||
20030188260, | |||
20040068489, | |||
20040073625, | |||
20040083213, | |||
JP10116173, | |||
JP2002123544, | |||
JP2002230005, | |||
JP2002245080, | |||
JP2003016089, | |||
JP2003162531, | |||
JP2003503798, | |||
JP59176823, | |||
JP6019965, | |||
JP6290221, | |||
JP9091309, | |||
JP9510565, | |||
WO180079, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jun 12 2003 | MARCJAN, CEZARY | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 014183 | /0293 | |
Jun 12 2003 | TURSKI, ANDRZEJ | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 014183 | /0293 | |
Jun 12 2003 | KOTT, RYSZARD | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 014183 | /0293 | |
Jun 13 2003 | Microsoft Corporation | (assignment on the face of the patent) | / | |||
Jun 13 2003 | VRONAY, DAVID P | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 014183 | /0285 | |
Oct 14 2014 | Microsoft Corporation | Microsoft Technology Licensing, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034541 | /0477 | |
May 16 2016 | Microsoft Technology Licensing, LLC | ZHIGU HOLDINGS LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 040354 | /0001 |
Date | Maintenance Fee Events |
Aug 09 2013 | ASPN: Payor Number Assigned. |
Nov 14 2016 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Mar 01 2017 | ASPN: Payor Number Assigned. |
Mar 01 2017 | RMPN: Payer Number De-assigned. |
Sep 28 2020 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
May 21 2016 | 4 years fee payment window open |
Nov 21 2016 | 6 months grace period start (w surcharge) |
May 21 2017 | patent expiry (for year 4) |
May 21 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
May 21 2020 | 8 years fee payment window open |
Nov 21 2020 | 6 months grace period start (w surcharge) |
May 21 2021 | patent expiry (for year 8) |
May 21 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
May 21 2024 | 12 years fee payment window open |
Nov 21 2024 | 6 months grace period start (w surcharge) |
May 21 2025 | patent expiry (for year 12) |
May 21 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |