US20160292218A1 - Extensible data query scenario definition and consumption - Google Patents
Extensible data query scenario definition and consumption Download PDFInfo
- Publication number
- US20160292218A1 US20160292218A1 US15/182,894 US201615182894A US2016292218A1 US 20160292218 A1 US20160292218 A1 US 20160292218A1 US 201615182894 A US201615182894 A US 201615182894A US 2016292218 A1 US2016292218 A1 US 2016292218A1
- Authority
- US
- United States
- Prior art keywords
- dataset
- user interface
- query
- sample
- format
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G06F17/30398—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/242—Query formulation
- G06F16/2428—Query predicate definition using graphical user interfaces, including menus and forms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/242—Query formulation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/242—Query formulation
- G06F16/2423—Interactive query statement specification based on a database schema
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/242—Query formulation
- G06F16/2425—Iterative querying; Query formulation based on the results of a preceding query
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/242—Query formulation
- G06F16/2433—Query languages
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2452—Query translation
- G06F16/24526—Internal representations for queries
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2457—Query processing with adaptation to user needs
- G06F16/24573—Query processing with adaptation to user needs using data annotations, e.g. user-defined metadata
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/903—Querying
- G06F16/9032—Query formulation
- G06F16/90324—Query formulation using system suggestions
- G06F16/90328—Query formulation using system suggestions using search space presentation or visualization, e.g. category or range presentation and selection
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/951—Indexing; Web crawling techniques
-
- G06F17/30392—
-
- G06F17/30395—
-
- G06F17/30404—
-
- G06F17/30436—
-
- G06F17/30525—
-
- G06F17/30973—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
Definitions
- Data publishers, web services, and others may offer datasets to potential subscribers via a data marketplace or other venues. Often the datasets are very large tables with many columns and rows. A subscriber who is interested in the dataset may not have sufficient knowledge of the dataset or its format to properly access the data. Subscribers and others who did not create the dataset may not know which columns to filter on and which columns to provide as query results.
- the general content of a dataset can be easily identified, for example, as weather, financial, geographic, or other data. However, it is not easy for subscribers to understand what type of information can be pulled from the dataset or how to construct queries to gather desired data. This may be a particular problem when using complex datasets that requires detailed knowledge of the dataset format in order to compose useful queries.
- dataset publishers provide examples of how to use their dataset in one embodiment.
- the publisher defines one or more questions that can be answered by the dataset.
- the publisher also defines the query code required to answer those questions.
- a subscriber is shown the example questions answered by the dataset and is provided code having the appropriate values that correspond to the question.
- One or more terms in the query may be highlighted or otherwise designated as variable or subscriber-selectable so that the subscriber can understand how to modify the sample query to ask other questions.
- the subscriber does not have to know how the dataset is organized in order to use the dataset, but instead can use the pre-formatted queries to begin using the dataset immediately.
- the subscriber's platform may not support the query language used by the dataset or the subscriber may not be familiar with the dataset's native format.
- a translation engine is used to translate the sample query, or other queries, to a target format selected by the subscriber. This allows the subscriber to obtain queries that both ask a desired question of the dataset and do so in a format that the subscriber can deploy in existing applications.
- Data brokers such as aggregators and marketplaces, may provide content providers, such as dataset publishers, with the ability to define scenarios for their datasets once and then rely on the aggregator to appropriately translate the scenario into sales and consumption models best suited for end-users.
- content providers define a set of scenarios that are addressed by their dataset.
- the scenarios include user-friendly, human-readable attributes such as a title, description, and visualization.
- the scenarios may also include a technical description that can be used to generate sample queries that can then be executed against the dataset.
- the technical description may be machine translated to arbitrary data querying protocols while maintaining the semantic meaning of the query.
- a user interface may be provided to allow users to intuitively generate the scenarios.
- an extensible framework provides for the creation of protocol-specific translation plug-ins that are used to generate implementations of the scenario suitable for selected protocols.
- Known market-relevant translator plug-ins may also be implemented.
- FIG. 1 is a block diagram illustrating a data marketplace that offers datasets and APIs to users according to one embodiment.
- FIG. 2 illustrates the type of information that a dataset publisher would provide to the data marketplace to publish the dataset in one embodiment.
- FIG. 3 illustrates dataset information provided to subscribers on the data marketplace according to one embodiment.
- FIG. 4 is a block diagram of a system for translating sample dataset queries to other formats according to one embodiment.
- FIG. 5 is a flowchart illustrating one method or process for receiving dataset information from a content provider or dataset publisher to be offered by a data broker according to one embodiment.
- FIG. 6 is a flowchart illustrating one method or process for providing dataset information to a user by a data broker according to one embodiment.
- FIG. 7 illustrates an example of a suitable computing and networking environment.
- FIG. 1 is a block diagram illustrating a data marketplace 101 that offers datasets and APIs to users according to one embodiment.
- Marketplace 101 comprises a plurality of datasets 102 - 104 that are available for use by subscribers.
- Marketplace 101 may be a website hosted on a web server that is accessed by subscribers via a public or private network 105 , such as an intranet or Internet. The subscribers may browse the available datasets 102 - 104 listed on data marketplace 101 .
- subscription and billing module 106 allows the subscriber to purchase a subscription to the selected content.
- the data marketplace content such as datasets 102 - 104 , is provided by dataset publishers 107 - 109 .
- the content may be uploaded to marketplace 101 by dataset publishers 107 - 109 via a public or private network 110 , such as an intranet or Internet.
- the datasets may be accessed remotely by the marketplace on behalf of subscribers.
- some or all of the publishers and developers are independent from and unrelated to the operator of marketplace 101 and the subscribers.
- Marketplace 101 provides a centralized location for the dataset publishers 107 - 109 to offer their content to potential subscribers.
- Dataset publishers 107 - 109 collect, correlate, and organize information on selected any subject matter.
- the data dataset publishers 107 - 109 then makes the processed information available as datasets 102 - 104 on data marketplace 101 .
- Datasets 102 - 104 may use a standardized protocol for querying data, such as the Open Data Protocol (OData).
- OData Open Data Protocol
- Dataset subscribers 111 - 114 may have an interest in or need for the information available in one or more datasets 102 - 104 .
- Data marketplace 101 allows a subscriber 111 - 114 to review many datasets from a number of different data publishers 107 - 109 without having to identify and seek out each dataset publisher separately.
- subscription and billing module 106 allows the subscriber to enter into a contract for access to the dataset.
- Subscription and billing module 106 also handles billing to the dataset subscriber and payment to dataset publisher.
- one or more datasets 102 - 104 are designed to operate in a cloud environment in which hosted services are delivered over the Internet or some other network. Subscriptions to datasets 102 - 104 may be sold on a flat-fee or an on-demand basis. Access to the datasets may also be elastic so that the user may have as much or as little of a dataset as required at any given time. Additionally, datasets 102 - 104 may be fully managed by the publishers 107 - 109 so that the subscriber needs nothing but a computer and network access to the dataset.
- Some datasets 102 - 104 may be adapted to operate on external datasets that are not available via data marketplace 101 .
- a subscriber to an external dataset may use an API to access the dataset.
- an API for the dataset may provide the subscriber with a link or access to such an external dataset.
- the subscribers 111 - 114 access the datasets using a selected query language or format. Different subscribers 111 - 114 may require different query formats based upon the application using the dataset.
- FIG. 2 illustrates the type of information 200 that a dataset publisher would provide to the data marketplace to publish the dataset in one embodiment.
- the dataset publisher provides dataset metadata 201 , such as a dataset name, billing structure, maintenance/update schedule, database type, or any other information that may be useful to the data marketplace to support the dataset.
- Connection string 202 is a pointer, address, or any other information required to identify the location of dataset 203 .
- the dataset 203 may be uploaded entirely to the data marketplace or it may be hosted externally by the dataset publisher or a third party.
- a first sample query 204 is provided by the dataset publisher.
- Query 204 is an example of how a subscriber may use and/or access dataset 203 .
- dataset 203 is a SQL database
- query 204 may be example T-SQL statements that a subscriber would use to communicate with dataset 203 for a particular query.
- Sample query 204 may identify certain query parameters 205 that can be modified. For example, if sample query 204 requests data for a certain year, the publisher may indicate that other dates 205 may also be used to query the dataset.
- the dataset publisher also may provide a description 206 of the query.
- Description 206 explains to potential subscribers what type of information may be pulled from the dataset and how the sample query is structured, for example.
- An image 207 illustrating the query results may be provided. For example, a chart, map, table, or some other visualization of the results of sample query 204 is shown in image 207 .
- Additional sample queries 208 with other selectable query terms 209 may also be provided by the publisher to illustrate additional information that can be collected from the dataset.
- the sample queries 204 and 208 may be in an appropriate syntax for the platform hosting dataset 203 .
- the subscribers may require or desire different query formats depending upon the platform used by the subscribers.
- the data marketplace translates the sample queries into other formats selected by the subscribers.
- FIG. 3 illustrates dataset information 300 provided to subscribers on the data marketplace according to one embodiment.
- the data marketplace may provide separate listings 300 for each dataset offered.
- the dataset listing 300 may include information collected from the dataset publisher, such as the information shown in FIG. 2 , and other features offered specifically by the data marketplace.
- the dataset name 301 is shown along with one or more sample queries 302 .
- the sample queries 302 may be selected from the publisher-provided information 204 and 208 and provide the potential subscriber with examples how the dataset may be used.
- Examples images 303 are provided for the output of the dataset using sample query 302 . These images may include charts, graphs, text, or any other output data format supported by the dataset.
- a description 304 of the dataset contents and they sample queries is also shown.
- the subscriber may not be able to use the format of the sample query, for example, if the subscriber's platform does not support the syntax of the sample query or if the subscriber is not familiar with that format.
- the data marketplace is capable of translating the sample queries into other formats so that the subscriber can evaluate how the dataset can be used in other applications. For example, the user may request the sample query in C# by selecting option 305 or in OData syntax by selecting option 306 . The data marketplace will then convert the sample query to a format requested by the subscriber. If the subscriber may then purchase access to the dataset using option 307 .
- FIG. 4 is a block diagram of a system for translating sample dataset queries to other formats according to one embodiment.
- a subscriber may select a target format for a sample query 401 listed with a database of interest.
- the sample query is provided to translation engine 402 , which converts the original query to a format selected by the subscriber. For example, if the offered sample query will not work on the subscriber's platform, then the query may translated into a web query user interface 403 , such as a format associated with the data marketplace, an OData query 404 , T-SQL query 405 , C# query 406 or any other appropriate query format 407 .
- Translation engine 402 may be a software application that is designed to convert statements from one query format to another. In some cases, translation engine 402 may not have the capability perform a desired translation. Extensibility API 408 may be used by translation engine 402 to access external translation applications, such as web translator 409 , OData translator 410 , T-SQL translator 411 , C# translator 412 , or any other translator 413 .
- the translator applications 409 - 413 may provide plug-in support for a platform-specific format required by the subscriber. The translator converts the sample query 401 and returns the query to engine 402 , which outputs the translated query to the user.
- query 401 is listed as a “sample query,” it will be understood that any valid query for a dataset may be used with translation engine 402 .
- other queries can be written for the dataset in the native format for the dataset. Those native-format queries may then be translated to a format appropriate to the subscriber's platform.
- FIG. 5 is a flowchart illustrating one method or process for receiving dataset information from a content provider or dataset publisher to be offered by a data broker according to one embodiment.
- step 501 information about a dataset is received at a data broker server from a content provider.
- the dataset is available for subscription by a user, which may be a periodic payment for continued use or a one-time purchase of dataset access.
- the dataset may be stored at the data broker server or at a location remote from the data broker server.
- the information received from the content provider may identify one or more use scenarios for the dataset in step 502 .
- the scenarios identify at least one query that can be answered by the dataset.
- a sample query code is received from the content provider in step 503 .
- the sample query code corresponds to the at least one query for the scenario.
- terms are identified in the sample query that can be modified by the user.
- the sample query code may be provided to the user.
- the sample query is provided to a translation engine for translation to a format selected by the user.
- the sample query may be translated to a protocol-specific format or a platform-specific format selected by the user.
- the translated query maintains the semantic meaning of the sample query.
- FIG. 6 is a flowchart illustrating one method or process for providing dataset information to a user by a data broker according to one embodiment.
- information about a dataset is displayed to a user.
- the dataset is available for subscription by the user, such as a recurring or one-time payment for access to the dataset.
- one or more use scenarios for the dataset are identified.
- the scenarios identify at least one query that can be answered by the selected dataset.
- Sample query code for the dataset is displayed in step 603 .
- the sample query code corresponds to the at least one query for the scenario.
- a request for the sample query code is received from the user.
- the sample query code is provided to the user in step 605 .
- a query-format identification may be received from the user.
- the sample query code may be provided to a translation engine for translation to the format selected by the user.
- the sample query may be translated to a protocol-specific format or a platform-specific format selected by the user.
- steps 501 - 505 of the process illustrated in FIG. 5 and steps 601 - 605 of the process illustrated in FIG. 6 may be executed simultaneously and/or sequentially. It will be further understood that each step may be performed in any order and may be performed once or repetitiously.
- FIG. 7 illustrates an example of a suitable computing and networking environment 700 on which the examples of FIGS. 1-4 may be implemented.
- the computing system environment 700 is only one example of a suitable computing environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention.
- the invention is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to: personal computers, server computers, hand-held or laptop devices, tablet devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
- the invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer.
- program modules include routines, programs, objects, components, data structures, and so forth, which perform particular tasks or implement particular abstract data types.
- the invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network.
- program modules may be located in local and/or remote computer storage media including memory storage devices.
- an exemplary system for implementing various aspects of the invention may include a general purpose computing device in the form of a computer 700 .
- Components may include, but are not limited to, various hardware components, such as processing unit 701 , data storage 702 , such as a system memory, and system bus 703 that couples various system components including the data storage 702 to the processing unit 701 .
- the system bus 703 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures.
- such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCI) bus also known as Mezzanine bus.
- ISA Industry Standard Architecture
- MCA Micro Channel Architecture
- EISA Enhanced ISA
- VESA Video Electronics Standards Association
- PCI Peripheral Component Interconnect
- Computer-readable media 704 may be any available media that can be accessed by the computer 700 and includes both volatile and nonvolatile media, and removable and non-removable media, but excludes propagated signals.
- Computer-readable media 704 may comprise computer storage media and communication media.
- Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data.
- Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by the computer 700 .
- Communication media typically embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media.
- modulated data signal means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal.
- communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above may also be included within the scope of computer-readable media.
- Computer-readable media may be embodied as a computer program product, such as software stored on computer storage media.
- the data storage or system memory 702 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) and random access memory (RAM).
- ROM read only memory
- RAM random access memory
- BIOS basic input/output system
- RAM typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 701 .
- data storage 702 holds an operating system, application programs, and other program modules and program data.
- Data storage 702 may also include other removable/non-removable, volatile/nonvolatile computer storage media.
- data storage 702 may be a hard disk drive that reads from or writes to non-removable, nonvolatile magnetic media, a magnetic disk drive that reads from or writes to a removable, nonvolatile magnetic disk, and an optical disk drive that reads from or writes to a removable, nonvolatile optical disk such as a CD ROM or other optical media.
- Other removable/non-removable, volatile/nonvolatile computer storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like.
- the drives and their associated computer storage media, described above and illustrated in FIG. 7 provide storage of computer-readable instructions, data structures, program modules and other data for the computer 700 .
- a user may enter commands and information through a user interface 705 or other input devices such as a tablet, electronic digitizer, a microphone, keyboard, and/or pointing device, commonly referred to as mouse, trackball or touch pad.
- Other input devices may include a joystick, game pad, satellite dish, scanner, or the like.
- voice inputs, gesture inputs using hands or fingers, or other natural user interface (NUI) may also be used with the appropriate input devices, such as a microphone, camera, tablet, touch pad, glove, or other sensor.
- NUI natural user interface
- These and other input devices are often connected to the processing unit 701 through a user input interface 705 that is coupled to the system bus 703 , but may be connected by other interface and bus structures, such as a parallel port, game port or a universal serial bus (USB).
- USB universal serial bus
- a monitor 706 or other type of display device is also connected to the system bus 703 via an interface, such as a video interface.
- the monitor 706 may also be integrated with a touch-screen panel or the like.
- the monitor and/or touch screen panel can be physically coupled to a housing in which the computing device 700 is incorporated, such as in a tablet-type personal computer.
- computers such as the computing device 700 may also include other peripheral output devices such as speakers and printer, which may be connected through an output peripheral interface or the like.
- the computer 700 may operate in a networked or cloud-computing environment using logical connections 707 to one or more remote devices, such as a remote computer.
- the remote computer may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 700 .
- the logical connections depicted in FIG. 7 include one or more local area networks (LAN) and one or more wide area networks (WAN), but may also include other networks.
- LAN local area networks
- WAN wide area network
- Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet.
- the computer 700 When used in a networked or cloud-computing environment, the computer 700 may be connected to a public or private network through a network interface or adapter 707 .
- a modem or other means for establishing communications over the network may be connected to the system bus 703 via the network interface 707 or other appropriate mechanism.
- a wireless networking component such as comprising an interface and antenna may be coupled through a suitable device such as an access point or peer computer to a network.
- program modules depicted relative to the computer 700 may be stored in the remote memory storage device. It may be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Databases & Information Systems (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- General Engineering & Computer Science (AREA)
- Computational Linguistics (AREA)
- Mathematical Physics (AREA)
- Business, Economics & Management (AREA)
- Accounting & Taxation (AREA)
- Development Economics (AREA)
- Finance (AREA)
- Strategic Management (AREA)
- Entrepreneurship & Innovation (AREA)
- Game Theory and Decision Science (AREA)
- Economics (AREA)
- Marketing (AREA)
- General Business, Economics & Management (AREA)
- Human Computer Interaction (AREA)
- Library & Information Science (AREA)
- Information Transfer Between Computers (AREA)
Abstract
Description
- This application is a continuation of U.S. patent application Ser. No. 13/517,611, filed Jun. 14, 2012, and entitled “EXTENSIBLE DATA QUERY SCENARIO DEFINITION AND CONSUMPTION,” and which issued as U.S. Pat. No. 9,372,884 on Jun. 21, 2016, the entire content of which is incorporated by reference herein in its entirety.
- Data publishers, web services, and others may offer datasets to potential subscribers via a data marketplace or other venues. Often the datasets are very large tables with many columns and rows. A subscriber who is interested in the dataset may not have sufficient knowledge of the dataset or its format to properly access the data. Subscribers and others who did not create the dataset may not know which columns to filter on and which columns to provide as query results.
- The general content of a dataset can be easily identified, for example, as weather, financial, geographic, or other data. However, it is not easy for subscribers to understand what type of information can be pulled from the dataset or how to construct queries to gather desired data. This may be a particular problem when using complex datasets that requires detailed knowledge of the dataset format in order to compose useful queries.
- In some cases, additional problems arise when the dataset uses a query format that is not compatible with the subscriber's platform.
- This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
- In addition to typical descriptions of the dataset contents, dataset publishers provide examples of how to use their dataset in one embodiment. When a dataset is offered to subscribers, the publisher defines one or more questions that can be answered by the dataset. The publisher also defines the query code required to answer those questions. In a data marketplace, for example, a subscriber is shown the example questions answered by the dataset and is provided code having the appropriate values that correspond to the question. One or more terms in the query may be highlighted or otherwise designated as variable or subscriber-selectable so that the subscriber can understand how to modify the sample query to ask other questions. As a result, the subscriber does not have to know how the dataset is organized in order to use the dataset, but instead can use the pre-formatted queries to begin using the dataset immediately.
- In some cases, the subscriber's platform may not support the query language used by the dataset or the subscriber may not be familiar with the dataset's native format. A translation engine is used to translate the sample query, or other queries, to a target format selected by the subscriber. This allows the subscriber to obtain queries that both ask a desired question of the dataset and do so in a format that the subscriber can deploy in existing applications.
- Data brokers, such as aggregators and marketplaces, may provide content providers, such as dataset publishers, with the ability to define scenarios for their datasets once and then rely on the aggregator to appropriately translate the scenario into sales and consumption models best suited for end-users.
- In one embodiment, content providers define a set of scenarios that are addressed by their dataset. The scenarios include user-friendly, human-readable attributes such as a title, description, and visualization. The scenarios may also include a technical description that can be used to generate sample queries that can then be executed against the dataset. The technical description may be machine translated to arbitrary data querying protocols while maintaining the semantic meaning of the query. A user interface may be provided to allow users to intuitively generate the scenarios.
- In one embodiment, an extensible framework provides for the creation of protocol-specific translation plug-ins that are used to generate implementations of the scenario suitable for selected protocols. Known market-relevant translator plug-ins may also be implemented.
- To further clarify the above and other advantages and features of embodiments of the present invention, a more particular description of embodiments of the present invention will be rendered by reference to the appended drawings. It is appreciated that these drawings depict only typical embodiments of the invention and are therefore not to be considered limiting of its scope. The invention will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:
-
FIG. 1 is a block diagram illustrating a data marketplace that offers datasets and APIs to users according to one embodiment. -
FIG. 2 illustrates the type of information that a dataset publisher would provide to the data marketplace to publish the dataset in one embodiment. -
FIG. 3 illustrates dataset information provided to subscribers on the data marketplace according to one embodiment. -
FIG. 4 is a block diagram of a system for translating sample dataset queries to other formats according to one embodiment. -
FIG. 5 is a flowchart illustrating one method or process for receiving dataset information from a content provider or dataset publisher to be offered by a data broker according to one embodiment. -
FIG. 6 is a flowchart illustrating one method or process for providing dataset information to a user by a data broker according to one embodiment. -
FIG. 7 illustrates an example of a suitable computing and networking environment. -
FIG. 1 is a block diagram illustrating adata marketplace 101 that offers datasets and APIs to users according to one embodiment.Marketplace 101 comprises a plurality of datasets 102-104 that are available for use by subscribers. Marketplace 101 may be a website hosted on a web server that is accessed by subscribers via a public orprivate network 105, such as an intranet or Internet. The subscribers may browse the available datasets 102-104 listed ondata marketplace 101. When a subscriber identifies useful or desired content inmarketplace 101, subscription andbilling module 106 allows the subscriber to purchase a subscription to the selected content. - The data marketplace content, such as datasets 102-104, is provided by dataset publishers 107-109. The content may be uploaded to
marketplace 101 by dataset publishers 107-109 via a public orprivate network 110, such as an intranet or Internet. Alternatively, the datasets may be accessed remotely by the marketplace on behalf of subscribers. In one embodiment, some or all of the publishers and developers are independent from and unrelated to the operator ofmarketplace 101 and the subscribers. Marketplace 101 provides a centralized location for the dataset publishers 107-109 to offer their content to potential subscribers. - Dataset publishers 107-109 collect, correlate, and organize information on selected any subject matter. The data dataset publishers 107-109 then makes the processed information available as datasets 102-104 on
data marketplace 101. Datasets 102-104 may use a standardized protocol for querying data, such as the Open Data Protocol (OData). Dataset subscribers 111-114 may have an interest in or need for the information available in one or more datasets 102-104.Data marketplace 101 allows a subscriber 111-114 to review many datasets from a number of different data publishers 107-109 without having to identify and seek out each dataset publisher separately. Once a subscriber selects a dataset, subscription andbilling module 106 allows the subscriber to enter into a contract for access to the dataset. Subscription andbilling module 106 also handles billing to the dataset subscriber and payment to dataset publisher. - In one embodiment, one or more datasets 102-104 are designed to operate in a cloud environment in which hosted services are delivered over the Internet or some other network. Subscriptions to datasets 102-104 may be sold on a flat-fee or an on-demand basis. Access to the datasets may also be elastic so that the user may have as much or as little of a dataset as required at any given time. Additionally, datasets 102-104 may be fully managed by the publishers 107-109 so that the subscriber needs nothing but a computer and network access to the dataset.
- Some datasets 102-104 may be adapted to operate on external datasets that are not available via
data marketplace 101. A subscriber to an external dataset may use an API to access the dataset. For example, an API for the dataset may provide the subscriber with a link or access to such an external dataset. The subscribers 111-114 access the datasets using a selected query language or format. Different subscribers 111-114 may require different query formats based upon the application using the dataset. -
FIG. 2 illustrates the type ofinformation 200 that a dataset publisher would provide to the data marketplace to publish the dataset in one embodiment. The dataset publisher providesdataset metadata 201, such as a dataset name, billing structure, maintenance/update schedule, database type, or any other information that may be useful to the data marketplace to support the dataset.Connection string 202 is a pointer, address, or any other information required to identify the location ofdataset 203. Thedataset 203 may be uploaded entirely to the data marketplace or it may be hosted externally by the dataset publisher or a third party. - A
first sample query 204 is provided by the dataset publisher.Query 204 is an example of how a subscriber may use and/oraccess dataset 203. For example, ifdataset 203 is a SQL database, then query 204 may be example T-SQL statements that a subscriber would use to communicate withdataset 203 for a particular query.Sample query 204 may identifycertain query parameters 205 that can be modified. For example, if sample query 204 requests data for a certain year, the publisher may indicate thatother dates 205 may also be used to query the dataset. - The dataset publisher also may provide a
description 206 of the query.Description 206 explains to potential subscribers what type of information may be pulled from the dataset and how the sample query is structured, for example. Animage 207 illustrating the query results may be provided. For example, a chart, map, table, or some other visualization of the results ofsample query 204 is shown inimage 207. - Additional sample queries 208 with other
selectable query terms 209 may also be provided by the publisher to illustrate additional information that can be collected from the dataset. The sample queries 204 and 208 may be in an appropriate syntax for theplatform hosting dataset 203. However, the subscribers may require or desire different query formats depending upon the platform used by the subscribers. In one embodiment, the data marketplace translates the sample queries into other formats selected by the subscribers. -
FIG. 3 illustratesdataset information 300 provided to subscribers on the data marketplace according to one embodiment. The data marketplace may provideseparate listings 300 for each dataset offered. Thedataset listing 300 may include information collected from the dataset publisher, such as the information shown inFIG. 2 , and other features offered specifically by the data marketplace. Thedataset name 301 is shown along with one or more sample queries 302. The sample queries 302 may be selected from the publisher-providedinformation Examples images 303 are provided for the output of the dataset usingsample query 302. These images may include charts, graphs, text, or any other output data format supported by the dataset. Adescription 304 of the dataset contents and they sample queries is also shown. - The subscriber may not be able to use the format of the sample query, for example, if the subscriber's platform does not support the syntax of the sample query or if the subscriber is not familiar with that format. Accordingly, the data marketplace is capable of translating the sample queries into other formats so that the subscriber can evaluate how the dataset can be used in other applications. For example, the user may request the sample query in C# by selecting
option 305 or in OData syntax by selectingoption 306. The data marketplace will then convert the sample query to a format requested by the subscriber. If the subscriber may then purchase access to thedataset using option 307. -
FIG. 4 is a block diagram of a system for translating sample dataset queries to other formats according to one embodiment. A subscriber may select a target format for asample query 401 listed with a database of interest. The sample query is provided totranslation engine 402, which converts the original query to a format selected by the subscriber. For example, if the offered sample query will not work on the subscriber's platform, then the query may translated into a webquery user interface 403, such as a format associated with the data marketplace, anOData query 404, T-SQL query 405,C# query 406 or any otherappropriate query format 407. -
Translation engine 402 may be a software application that is designed to convert statements from one query format to another. In some cases,translation engine 402 may not have the capability perform a desired translation.Extensibility API 408 may be used bytranslation engine 402 to access external translation applications, such asweb translator 409,OData translator 410, T-SQL translator 411,C# translator 412, or anyother translator 413. The translator applications 409-413 may provide plug-in support for a platform-specific format required by the subscriber. The translator converts thesample query 401 and returns the query toengine 402, which outputs the translated query to the user. - Although
query 401 is listed as a “sample query,” it will be understood that any valid query for a dataset may be used withtranslation engine 402. Once a user subscribes to the dataset, other queries can be written for the dataset in the native format for the dataset. Those native-format queries may then be translated to a format appropriate to the subscriber's platform. -
FIG. 5 is a flowchart illustrating one method or process for receiving dataset information from a content provider or dataset publisher to be offered by a data broker according to one embodiment. Instep 501, information about a dataset is received at a data broker server from a content provider. The dataset is available for subscription by a user, which may be a periodic payment for continued use or a one-time purchase of dataset access. The dataset may be stored at the data broker server or at a location remote from the data broker server. The information received from the content provider may identify one or more use scenarios for the dataset instep 502. The scenarios identify at least one query that can be answered by the dataset. - A sample query code is received from the content provider in
step 503. The sample query code corresponds to the at least one query for the scenario. Instep 504, terms are identified in the sample query that can be modified by the user. The sample query code may be provided to the user. Instep 505, the sample query is provided to a translation engine for translation to a format selected by the user. The sample query may be translated to a protocol-specific format or a platform-specific format selected by the user. The translated query maintains the semantic meaning of the sample query. -
FIG. 6 is a flowchart illustrating one method or process for providing dataset information to a user by a data broker according to one embodiment. Instep 601, information about a dataset is displayed to a user. The dataset is available for subscription by the user, such as a recurring or one-time payment for access to the dataset. Instep 602, one or more use scenarios for the dataset are identified. The scenarios identify at least one query that can be answered by the selected dataset. Sample query code for the dataset is displayed instep 603. The sample query code corresponds to the at least one query for the scenario. - In
step 604, a request for the sample query code is received from the user. The sample query code is provided to the user instep 605. In some embodiments, a query-format identification may be received from the user. The sample query code may be provided to a translation engine for translation to the format selected by the user. The sample query may be translated to a protocol-specific format or a platform-specific format selected by the user. - It will be understood that steps 501-505 of the process illustrated in
FIG. 5 and steps 601-605 of the process illustrated inFIG. 6 may be executed simultaneously and/or sequentially. It will be further understood that each step may be performed in any order and may be performed once or repetitiously. -
FIG. 7 illustrates an example of a suitable computing andnetworking environment 700 on which the examples ofFIGS. 1-4 may be implemented. Thecomputing system environment 700 is only one example of a suitable computing environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention. The invention is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to: personal computers, server computers, hand-held or laptop devices, tablet devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like. - The invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, and so forth, which perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in local and/or remote computer storage media including memory storage devices.
- With reference to
FIG. 7 , an exemplary system for implementing various aspects of the invention may include a general purpose computing device in the form of acomputer 700. Components may include, but are not limited to, various hardware components, such asprocessing unit 701,data storage 702, such as a system memory, andsystem bus 703 that couples various system components including thedata storage 702 to theprocessing unit 701. Thesystem bus 703 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCI) bus also known as Mezzanine bus. - The
computer 700 typically includes a variety of computer-readable media 704. Computer-readable media 704 may be any available media that can be accessed by thecomputer 700 and includes both volatile and nonvolatile media, and removable and non-removable media, but excludes propagated signals. By way of example, and not limitation, computer-readable media 704 may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by thecomputer 700. Communication media typically embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above may also be included within the scope of computer-readable media. Computer-readable media may be embodied as a computer program product, such as software stored on computer storage media. - The data storage or
system memory 702 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) and random access memory (RAM). A basic input/output system (BIOS), containing the basic routines that help to transfer information between elements withincomputer 700, such as during start-up, is typically stored in ROM. RAM typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processingunit 701. By way of example, and not limitation,data storage 702 holds an operating system, application programs, and other program modules and program data. -
Data storage 702 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,data storage 702 may be a hard disk drive that reads from or writes to non-removable, nonvolatile magnetic media, a magnetic disk drive that reads from or writes to a removable, nonvolatile magnetic disk, and an optical disk drive that reads from or writes to a removable, nonvolatile optical disk such as a CD ROM or other optical media. Other removable/non-removable, volatile/nonvolatile computer storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like. The drives and their associated computer storage media, described above and illustrated inFIG. 7 , provide storage of computer-readable instructions, data structures, program modules and other data for thecomputer 700. - A user may enter commands and information through a
user interface 705 or other input devices such as a tablet, electronic digitizer, a microphone, keyboard, and/or pointing device, commonly referred to as mouse, trackball or touch pad. Other input devices may include a joystick, game pad, satellite dish, scanner, or the like. Additionally, voice inputs, gesture inputs using hands or fingers, or other natural user interface (NUI) may also be used with the appropriate input devices, such as a microphone, camera, tablet, touch pad, glove, or other sensor. These and other input devices are often connected to theprocessing unit 701 through auser input interface 705 that is coupled to thesystem bus 703, but may be connected by other interface and bus structures, such as a parallel port, game port or a universal serial bus (USB). Amonitor 706 or other type of display device is also connected to thesystem bus 703 via an interface, such as a video interface. Themonitor 706 may also be integrated with a touch-screen panel or the like. Note that the monitor and/or touch screen panel can be physically coupled to a housing in which thecomputing device 700 is incorporated, such as in a tablet-type personal computer. In addition, computers such as thecomputing device 700 may also include other peripheral output devices such as speakers and printer, which may be connected through an output peripheral interface or the like. - The
computer 700 may operate in a networked or cloud-computing environment usinglogical connections 707 to one or more remote devices, such as a remote computer. The remote computer may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to thecomputer 700. The logical connections depicted inFIG. 7 include one or more local area networks (LAN) and one or more wide area networks (WAN), but may also include other networks. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet. - When used in a networked or cloud-computing environment, the
computer 700 may be connected to a public or private network through a network interface oradapter 707. In some embodiments, a modem or other means for establishing communications over the network. The modem, which may be internal or external, may be connected to thesystem bus 703 via thenetwork interface 707 or other appropriate mechanism. A wireless networking component such as comprising an interface and antenna may be coupled through a suitable device such as an access point or peer computer to a network. In a networked environment, program modules depicted relative to thecomputer 700, or portions thereof, may be stored in the remote memory storage device. It may be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used. - Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
Claims (20)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/182,894 US20160292218A1 (en) | 2012-06-14 | 2016-06-15 | Extensible data query scenario definition and consumption |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/517,611 US9372884B2 (en) | 2012-06-14 | 2012-06-14 | Extensible data query scenario definition and consumption |
US15/182,894 US20160292218A1 (en) | 2012-06-14 | 2016-06-15 | Extensible data query scenario definition and consumption |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/517,611 Continuation US9372884B2 (en) | 2012-06-14 | 2012-06-14 | Extensible data query scenario definition and consumption |
Publications (1)
Publication Number | Publication Date |
---|---|
US20160292218A1 true US20160292218A1 (en) | 2016-10-06 |
Family
ID=49756897
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/517,611 Active 2032-07-31 US9372884B2 (en) | 2012-06-14 | 2012-06-14 | Extensible data query scenario definition and consumption |
US15/182,894 Abandoned US20160292218A1 (en) | 2012-06-14 | 2016-06-15 | Extensible data query scenario definition and consumption |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/517,611 Active 2032-07-31 US9372884B2 (en) | 2012-06-14 | 2012-06-14 | Extensible data query scenario definition and consumption |
Country Status (1)
Country | Link |
---|---|
US (2) | US9372884B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10545737B2 (en) | 2017-06-13 | 2020-01-28 | Microsoft Technology Licensing, Llc | Model binding for command line parsers |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9372884B2 (en) * | 2012-06-14 | 2016-06-21 | Microsoft Technology Licensing, Llc | Extensible data query scenario definition and consumption |
US10997190B2 (en) * | 2016-02-01 | 2021-05-04 | Splunk Inc. | Context-adaptive selection options in a modular visualization framework |
Citations (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030016250A1 (en) * | 2001-04-02 | 2003-01-23 | Chang Edward Y. | Computer user interface for perception-based information retrieval |
US20030061205A1 (en) * | 2001-09-27 | 2003-03-27 | Cleghorn Monica Rose | System and method for processing database queries |
US6578046B2 (en) * | 1998-04-01 | 2003-06-10 | International Business Machines Corporation | Federated searches of heterogeneous datastores using a federated datastore object |
US20040215612A1 (en) * | 2003-04-28 | 2004-10-28 | Moshe Brody | Semi-boolean arrangement, method, and system for specifying and selecting data objects to be retrieved from a collection |
US20050171934A1 (en) * | 2004-01-30 | 2005-08-04 | Paul Yuknewicz | System and method for generating a parameterized query |
US6931396B1 (en) * | 1999-06-29 | 2005-08-16 | Gene Logic Inc. | Biological data processing |
US20060004725A1 (en) * | 2004-06-08 | 2006-01-05 | Abraido-Fandino Leonor M | Automatic generation of a search engine for a structured document |
US7027975B1 (en) * | 2000-08-08 | 2006-04-11 | Object Services And Consulting, Inc. | Guided natural language interface system and method |
US20070226242A1 (en) * | 2006-03-27 | 2007-09-27 | Oracle International Corporation | Search Based Application Development Framework |
US20080091448A1 (en) * | 2006-10-16 | 2008-04-17 | Niheu Eric K | System and method of integrating enterprise applications |
US20100121869A1 (en) * | 2008-11-07 | 2010-05-13 | Yann Le Biannic | Normalizing a filter condition of a database query |
US7984060B2 (en) * | 2003-07-15 | 2011-07-19 | International Business Machines Corporation | Model content provider with reusable components for supporting a plurality of GUI API's |
US20120191716A1 (en) * | 2002-06-24 | 2012-07-26 | Nosa Omoigui | System and method for knowledge retrieval, management, delivery and presentation |
US8635173B2 (en) * | 2010-03-12 | 2014-01-21 | Microsoft Corporation | Semantics update and adaptive interfaces in connection with information as a service |
US9372884B2 (en) * | 2012-06-14 | 2016-06-21 | Microsoft Technology Licensing, Llc | Extensible data query scenario definition and consumption |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6678700B1 (en) | 2000-04-27 | 2004-01-13 | General Atomics | System of and method for transparent management of data objects in containers across distributed heterogenous resources |
US6799184B2 (en) * | 2001-06-21 | 2004-09-28 | Sybase, Inc. | Relational database system providing XML query support |
US20030154090A1 (en) | 2001-08-08 | 2003-08-14 | Bernstein Steve L. | Dynamically generating and delivering information in response to the occurrence of an event |
US7693973B2 (en) | 2003-08-28 | 2010-04-06 | International Business Machines Corporation | Pluggable state meta-data processors based on meta information modeling in a service oriented architecture |
US7761406B2 (en) * | 2004-03-16 | 2010-07-20 | International Business Machines Corporation | Regenerating data integration functions for transfer from a data integration platform |
US7792811B2 (en) * | 2005-02-16 | 2010-09-07 | Transaxtions Llc | Intelligent search with guiding info |
US9104287B2 (en) | 2005-10-27 | 2015-08-11 | International Business Machines Corporation | System and method for data collection interface creation and data collection administration |
US20080103794A1 (en) | 2006-11-01 | 2008-05-01 | Microsoft Corporation | Virtual scenario generator |
US8407199B2 (en) * | 2011-04-28 | 2013-03-26 | International Business Machines Corporation | Graphic query suggestion apparatus and program product |
-
2012
- 2012-06-14 US US13/517,611 patent/US9372884B2/en active Active
-
2016
- 2016-06-15 US US15/182,894 patent/US20160292218A1/en not_active Abandoned
Patent Citations (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6578046B2 (en) * | 1998-04-01 | 2003-06-10 | International Business Machines Corporation | Federated searches of heterogeneous datastores using a federated datastore object |
US6931396B1 (en) * | 1999-06-29 | 2005-08-16 | Gene Logic Inc. | Biological data processing |
US7027975B1 (en) * | 2000-08-08 | 2006-04-11 | Object Services And Consulting, Inc. | Guided natural language interface system and method |
US20030016250A1 (en) * | 2001-04-02 | 2003-01-23 | Chang Edward Y. | Computer user interface for perception-based information retrieval |
US20030061205A1 (en) * | 2001-09-27 | 2003-03-27 | Cleghorn Monica Rose | System and method for processing database queries |
US20120191716A1 (en) * | 2002-06-24 | 2012-07-26 | Nosa Omoigui | System and method for knowledge retrieval, management, delivery and presentation |
US20040215612A1 (en) * | 2003-04-28 | 2004-10-28 | Moshe Brody | Semi-boolean arrangement, method, and system for specifying and selecting data objects to be retrieved from a collection |
US7984060B2 (en) * | 2003-07-15 | 2011-07-19 | International Business Machines Corporation | Model content provider with reusable components for supporting a plurality of GUI API's |
US20050171934A1 (en) * | 2004-01-30 | 2005-08-04 | Paul Yuknewicz | System and method for generating a parameterized query |
US20060004725A1 (en) * | 2004-06-08 | 2006-01-05 | Abraido-Fandino Leonor M | Automatic generation of a search engine for a structured document |
US20070226242A1 (en) * | 2006-03-27 | 2007-09-27 | Oracle International Corporation | Search Based Application Development Framework |
US20080091448A1 (en) * | 2006-10-16 | 2008-04-17 | Niheu Eric K | System and method of integrating enterprise applications |
US20100121869A1 (en) * | 2008-11-07 | 2010-05-13 | Yann Le Biannic | Normalizing a filter condition of a database query |
US8635173B2 (en) * | 2010-03-12 | 2014-01-21 | Microsoft Corporation | Semantics update and adaptive interfaces in connection with information as a service |
US9372884B2 (en) * | 2012-06-14 | 2016-06-21 | Microsoft Technology Licensing, Llc | Extensible data query scenario definition and consumption |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10545737B2 (en) | 2017-06-13 | 2020-01-28 | Microsoft Technology Licensing, Llc | Model binding for command line parsers |
Also Published As
Publication number | Publication date |
---|---|
US20130339382A1 (en) | 2013-12-19 |
US9372884B2 (en) | 2016-06-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11362923B2 (en) | Techniques for infrastructure analysis of internet-based activity | |
US11375044B2 (en) | Custom digital components | |
US11288319B1 (en) | Generating trending natural language request recommendations | |
US9632670B2 (en) | OData service provisioning on top of genil layer | |
US9495429B2 (en) | Automatic synthesis and presentation of OLAP cubes from semantically enriched data sources | |
US10372769B2 (en) | Displaying results, in an analytics visualization dashboard, of federated searches across repositories using as inputs attributes of the analytics visualization dashboard | |
US20140330821A1 (en) | Recommending context based actions for data visualizations | |
EP2369480A2 (en) | Mashup infrastructure with learning mechanism | |
US20130339924A1 (en) | Gateway data distribution engine | |
US20170060966A1 (en) | Action Recommendation System For Focused Objects | |
US20160012074A1 (en) | System and method for providing contextual analytics data | |
US20240073222A1 (en) | Techniques for managing projects and monitoring network-based assets | |
US11848830B2 (en) | Techniques for detection and analysis of network assets under common management | |
US20160292218A1 (en) | Extensible data query scenario definition and consumption | |
US20220108359A1 (en) | System and method for continuous automated universal rating aggregation and generation | |
US20160350344A1 (en) | Storage and access time for records | |
US20080313603A1 (en) | User interface archive | |
US20190171749A1 (en) | Data integration framework for multiple data providers using service url | |
JP6219425B2 (en) | Attribute information generation device, linkage system, and attribute information generation program | |
US20220180452A1 (en) | Automated Web Content Publishing | |
US20240296166A1 (en) | Deep Connectivity Between Disparate Database Systems | |
EP2657858A2 (en) | Odata service provisioning on top of genil layer | |
GB2597384A (en) | Custom digital components |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: MICROSOFT CORPORATION, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:PUSZKIEWICZ, PIOTR MILOSZ;MALL, ROGER;KASPERSKI, ZIV;AND OTHERS;REEL/FRAME:038918/0447 Effective date: 20120611 Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:038918/0531 Effective date: 20141014 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |