Simplified query language for accessing metadata

US9542439B1 · US · B1

Patent metadata
FieldValue
Publication numberUS-9542439-B1
Application numberUS-201313917999-A
CountryUS
Kind codeB1
Filing dateJun 14, 2013
Priority dateJun 14, 2013
Publication dateJan 10, 2017
Grant dateJan 10, 2017

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

A CaQL API is provided by receiving a query directed to a catalog that includes metadata. A catalog access target is determined based at least in part on one or more of the following: a CaQL keyword which is included in the query, a name of a table in the catalog which is included in the query, or a predicate which is included in the query. A catalog function is generated based at least in part on the CaQL keyword and the catalog function is performed on the catalog access target.

First claim

Opening claim text (preview).

What is claimed is: 1. A method for providing a catalog query language (CaQL) application programming interface (API), comprising: receiving, at a processor which performs the CaQL API, a query associated with performing an operation on a first table in a catalog, wherein the catalog includes metadata; using the processor to determine a catalog access target, wherein: determination of the catalog access target is based at least in part on one or more of the following: a catalog query language (CaQL) keyword which identifies the operation and is included in the query, the name of the first table in the catalog which is included in the query, or a predicate which is included in the query; the first table is located in a plurality of locations in the catalog, including two or more of the following: a heap, an index, a system table, or a system cache; and determination of the catalog access target includes selecting, based at least in part on the operation, a location from the plurality of locations such that the selected location includes one and only one of the following: the heap, the index, the system table, or the system cache; using the processor to determine if there is a preexisting lock on a second table that can be reused for the first table, wherein the first table is different from the second table; in the event it is determined that there is a preexisting lock on the second table that can be reused for the first table, using the processor to determine if the strength of the preexisting lock on the second table is sufficient; in the event: (a) it is determined that there is a preexisting lock on the second table that can be reused for the first table and (b) it is determined that the strength of the preexisting lock on the second table is not sufficient, obtaining a new lock for the first table; in the event: (1) it is determined that there is a preexisting lock on the second table that can be reused for the first table and (2) it is determined that the strength of the preexisting lock on the second table is sufficient, reusing the preexisting lock on the second table for the first table; generating, based at least in part on the CaQL keyword, a catalog function; and performing the catalog function on the selected location, and wherein in the event there is a lock on the second table and the first table depends from the second table, it is determined that there is a preexisting lock on the second table that can be reused for the first table; and in the event there is a lock on the second table and the first table does not depend from the second table, the lock on the second table does not count as a preexisting lock on the second table that can be reused for the first table. 2. The method of claim 1 , wherein the method is performed by one or more of the following: an external catalog system or a unified catalog service (UCS) supported system. 3. The method of claim 1 , wherein the CaQL keyword is associated with a Data Manipulation Language (DML) and excludes a Data Definition Language (DDL). 4. The method of claim 1 , wherein the CaQL keyword is associated with one or more of the following: selecting content in a table, inserting content into a table, or deleting content in a table without dropping the entire table. 5. The method of claim 1 further comprising providing an interface for creating a user-defined locking mode, including by: receiving a name for the user-defined locking mode; receiving, for the user-defined locking mode, locking information; and storing at least the locking information, wherein the name and the locking information are associated so that the stored locking information is able to be retrieved using the name. 6. The method of claim 5 further comprising: determining if the name of the user-defined locking mode is received; in the event the name of the user-defined locking mode is not received, performing a default locking process; and in the event the name of the user-defined locking mode is received: obtaining the stored locking information using the name; and performing the user-defined locking process based at least in part on the stored locking information. 7. A system for providing a catalog query language (CaQL) application programming interface (API), comprising: a processor; and a memory coupled with the processor, wherein the memory is configured to provide the processor with instructions which when executed cause the processor to: receive, at the processor, a query associated with performing an operation on a first table in a catalog, wherein the catalog includes metadata; determine a catalog access target, wherein: determination of the catalog access target is based at least in part on one or more of the following: a catalog query language (CaQL) keyword which identifies the operation and is included in the query, the name of the first table in the catalog which is included in the query, or a predicate which is included in the query; the first table is located in a plurality of locations in the catalog, including two or more of the following: a heap, an index, a system table, or a system cache; and determination of the catalog access target includes selecting, based at least in part on the operation, a location from the plurality of locations such that the selected location includes one and only one of the following: the heap, the index, the system table, or the system cache; determine if there is a preexisting lock on a second table that can be reused for the first table, wherein the first table is different from the second table; in the event it is determined that there is a preexisting lock on the second table that can be reused for the first table, determine if the strength of the preexisting lock on the second table is sufficient; in the event: (a) it is determined that there is a preexisting lock on the second table that can be reused for the first table and (b) it is determined that the strength of the preexisting lock on the second table is not sufficient, obtain a new lock for the first table; in the event: (1) it is determined that there is a preexisting lock on the second table that can be reused for the first table and (2) it is determined that the strength of the preexisting lock on the second table is sufficient, reuse the preexisting lock on the second table for the first table; generate, based at least in part on the CaQL keyword, a catalog function; and perform the catalog function on the selected location, and wherein in the event there is a lock on the second table and the first table depends from the second table, it is determined that there is a preexisting lock on the second table that can be reused for the first table; and in the event there is a lock on the second table and the first table does not depend from the second table, the lock on the second table does not count as a preexisting lock on the second table that can be reused for the first table. 8. The system of claim 7 , wherein the memory is further configured to provide the processor with instructions which when executed cause the processor to provide an interface for creating a user-defined locking mode, including by: receiving a name for the user-defined locking mode; receiving, for the user-defined locking mode, locking information; and storing at least the locking information, wherein the name and the locking information are associated so that the stored locking information is able to be retrieved using the name. 9. The system of claim 8 , wherein the memory is further configured to provide the processor with instructions which when executed cause the processor to: determine if the name of the user-defined locking mode is received; in the event the na

Assignees

Inventors

Classifications

  • Physics · mapped topic

  • Physics · mapped topic

  • Physics · mapped topic

  • Pessimistic concurrency control approaches, e.g. locking or multiple versions without time stamps · CPC title

  • Integrating or interfacing systems involving database management systems · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9542439B1 cover?
A CaQL API is provided by receiving a query directed to a catalog that includes metadata. A catalog access target is determined based at least in part on one or more of the following: a CaQL keyword which is included in the query, a name of a table in the catalog which is included in the query, or a predicate which is included in the query. A catalog function is generated based at least in part…
Who is the assignee on this patent?
Emc Corp
What technology area does this patent fall under?
Primary CPC classification G06F17/30404. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jan 10 2017 00:00:00 GMT+0000 (Coordinated Universal Time) (B1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).