US7917463B2 - System and method for data warehousing and analytics on a distributed file system - Google Patents
System and method for data warehousing and analytics on a distributed file system Download PDFInfo
- Publication number
- US7917463B2 US7917463B2 US12/249,780 US24978008A US7917463B2 US 7917463 B2 US7917463 B2 US 7917463B2 US 24978008 A US24978008 A US 24978008A US 7917463 B2 US7917463 B2 US 7917463B2
- Authority
- US
- United States
- Prior art keywords
- map
- program
- ansi sql
- list
- expression
- 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.)
- Active, expires
Links
- 238000000034 method Methods 0.000 title claims abstract description 54
- 230000014509 gene expression Effects 0.000 claims abstract description 117
- 101710105312 Branched-chain-amino-acid aminotransferase Proteins 0.000 claims description 18
- 101710097328 Branched-chain-amino-acid aminotransferase, cytosolic Proteins 0.000 claims description 18
- 101710194298 Branched-chain-amino-acid aminotransferase, mitochondrial Proteins 0.000 claims description 18
- 101710158343 Probable branched-chain-amino-acid aminotransferase Proteins 0.000 claims description 18
- 101710199693 Putative branched-chain-amino-acid aminotransferase Proteins 0.000 claims description 18
- AZPBDRUPTRGILK-UHFFFAOYSA-N benzotriazol-1-ium-1-ylidenemethanediamine;4-methylbenzenesulfonate Chemical compound CC1=CC=C(S(O)(=O)=O)C=C1.C1=CC=C2N(C(=N)N)N=NC2=C1 AZPBDRUPTRGILK-UHFFFAOYSA-N 0.000 claims description 18
- 230000007246 mechanism Effects 0.000 claims description 8
- 238000000638 solvent extraction Methods 0.000 claims description 2
- 238000004590 computer program Methods 0.000 claims 7
- 238000005192 partition Methods 0.000 claims 3
- 230000008878 coupling Effects 0.000 claims 1
- 238000010168 coupling process Methods 0.000 claims 1
- 238000005859 coupling reaction Methods 0.000 claims 1
- 230000008569 process Effects 0.000 description 40
- 239000003638 chemical reducing agent Substances 0.000 description 19
- 230000006870 function Effects 0.000 description 19
- 230000008439 repair process Effects 0.000 description 18
- 238000003860 storage Methods 0.000 description 12
- 238000012552 review Methods 0.000 description 10
- 238000012545 processing Methods 0.000 description 9
- 230000001464 adherent effect Effects 0.000 description 6
- 230000002776 aggregation Effects 0.000 description 6
- 238000004220 aggregation Methods 0.000 description 6
- 238000013459 approach Methods 0.000 description 6
- 238000004891 communication Methods 0.000 description 3
- 230000000135 prohibitive effect Effects 0.000 description 3
- 230000009466 transformation Effects 0.000 description 3
- 102000020897 Formins Human genes 0.000 description 2
- 108091022623 Formins Proteins 0.000 description 2
- 230000004075 alteration Effects 0.000 description 2
- 238000007418 data mining Methods 0.000 description 2
- 230000008676 import Effects 0.000 description 2
- 238000004519 manufacturing process Methods 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 241000132092 Aster Species 0.000 description 1
- 230000004931 aggregating effect Effects 0.000 description 1
- 238000004458 analytical method Methods 0.000 description 1
- 238000007405 data analysis Methods 0.000 description 1
- 238000013075 data extraction Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 230000004069 differentiation Effects 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000011156 evaluation Methods 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 238000000926 separation method Methods 0.000 description 1
- 238000000844 transformation Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/18—File system types
- G06F16/182—Distributed file systems
Definitions
- the present invention relates to the field of data warehousing, and more specifically to querying data using ANSI Structured Query Language (SQL) expressions when the data resides in flat files over one or more local file systems connected by a network, by converting the SQL queries into a map-reduce program and executing the map-reduce program either directly on the local file system or on a distributed file system.
- SQL Structured Query Language
- Example data include (i) web log data tracking user activity on a e-commerce or other website; (ii) telephone log data from large telecommunications providers; (iii) system monitoring log data in large IT operations where systems track and monitor events. For large enterprises, this data reaches terabyte and petabyte sizes and resides over multiple storage devices.
- the existing approaches for querying this data involves the process of data extraction, transform, and load (ETL) wherein the data is loaded into a relational database management system (RDBMS). This process is expensive, time consuming, and for large data sizes it requires a significant investment in managing and maintaining a cluster of RDBMS to enable efficient querying of the data.
- ETL data extraction, transform, and load
- RDBMS relational database management system
- the hardware and personnel investment cost alone is prohibitive for all but the largest of enterprises when the data sizes reach terabytes. Yet even small internet sites and e-commerce sites can generate terabytes of data.
- the prohibitive cost of creating and maintaining the appropriate size cluster of RDBMSs makes access to the information and knowledge stored in much of that data inaccessible to those businesses.
- procurement and maintenance cost may be less of an issue, but the opportunity cost from delays in accessing the data can be material especially when new data sources need to be accessed.
- the typical time span required to go from flat files to ETL and to a performance ready cluster of RDBMS is measured in months.
- the first approach is RDBMS centric and involves horizontal partitioning of tables across multiple nodes in the cluster and customizing the query processing component of the RDBMS to enable parallel execution of SQL expressions.
- the second approach involves using a map-reduce programming framework to extract ad-hoc information from flat files.
- These approaches range from Google's Sawzall [ 8 ] which requires the user to write a map-reduce program specific to the task to Yahoo's PIG [ 7 ] and Facebook's HIVE [ 1 ] where the user interacts through a query or programming abstraction interface where the queries/programs articulate data analysis tasks in terms of higher-level transformations.
- HIVE provides some data warehousing functionality.
- PIG and HIVE create a high-level programming language that allows the user to program their requirements versus a declarative language where the user expresses what they need.
- PIG is not designed as a database system and therefore does not support key features such as (i) separation of the schema describing the data from the application that uses the data; (ii) indexing of the data to optimize performance; or (iii) views so that the application programs do not need to be rewritten when the schema changes.
- HIVE requires processing of the data in the local file systems with the objective of storing the data in a unique format necessary for HIVE to operate on the data [ 1 , 9 ]. This step is reminiscent of the costly and time consuming ETL step of RDBMS systems.
- map-reduce approaches such as PIG and Sawzall differ from the current invention in several key respects.
- the most obvious point of differentiation is that the primary objective of those systems is to create a programming language on top of map-reduce.
- HIVE provides some data warehousing functionality, but in contrast to HIVE, (i) the present invention creates a database system directly on the flat files and converts input ANSI SQL expressions into map-reduce programs for processing the expression on those flat files; (ii) the present invention allows data-centric applications that access data through ANSI SQL expressions to continue to operate correctly even as data layouts and database hardware evolves.
- Existing application programs such as reporting applications, business intelligence tools, OLAP systems, and data mining applications can use this invention as their database system without the user having to rewrite the application program; (iii) the present invention does not require the user or application to pre-process the data residing on the local file system as a pre-condition for analysis.
- the BCAT aggregate operator is unique to the present invention and it is not supported by RDBMS systems, HIVE, or PIG, and nor can it be derived directly from ANSI SQL expressions.
- a user In analyzing website traffic, for example, a user is often interested in aggregating user sessions on the website by the nodes (pages) they visited during the session.
- the session ID and node ID need to be columns and hence the user's path through the website is stored in multiple records. This representation is termed a “denormalized” representation and is necessary because the data warehouse designer does not know a priori how many nodes the user may visit in a single session.
- the business analyst is interested in grouping the sessions by the user's path, that is, by the nodes visited and in the order they were visited. Based on those groupings the analyst will compute financial and user metrics of interest.
- the approach would entail determining the longest user path, say M, and creating a normalized representation of the data which included M node columns to transform what is a row-oriented computation into a column-oriented computation that ANSI SQL can support.
- the above transformation of the data would be prohibitive for even moderately large data sets.
- the length of the longest path may continue to increase with new data, requiring in the worst case, the business analyst or data warehouse administrator to re-transform the data multiple times.
- the same problem cannot be solved by a column-oriented database, the latter which would also entail the same transformation of the data.
- the BCAT aggregate operator emphasizes a key aspect of the present invention that enables the analyst to create new dimensions from the data on-the-fly using row values.
- the RDBMS solution is to create a normalized representation of the data that contain the dimensions of interest. Creating such a representation requires creating a schema and the ETL process and programs to load the denormalized data into the new schema. That process is expensive and time consuming, and introduces significant performance bottlenecks that make it intractable for large data sets. That is one of the problems solved by the present invention.
- Log data produced by production systems is universally denormalized, and because the objective of this invention is to enable analysts and applications to process ANSI SQL queries directly on those data files without going through the complex and time consuming process of defining the schemas and writing ETL, the BCAT command enables the end-user, the business analyst, to create any number of on-the-fly dimensional views of the data by scripting ANSI SQL expressions.
- BCAT aggregate operator on node ID creates a new dimension path that is the concatenation of the node IDs in the order they were visited by the user.
- the outer select aggregates over the new path dimension.
- FIG. 1 illustrates an exemplary computing and data communications environment configured in accordance with one embodiment of the present invention.
- FIG. 2 illustrates an exemplary process of the data manipulations from input ANSI SQL query and flat files to the output result set in accordance with one embodiment of the present invention.
- FIG. 3 is a flow chart illustrating an exemplary process for converting an ANSI SQL query into a map-reduce program, running said program on a distributed file system and storing the output in the same file system in accordance with one embodiment of the present invention.
- FIG. 4 is a flow chart illustrating an exemplary process for converting a select-where ANSI SQL query into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention.
- FIG. 5( a ) is a flow chart illustrating an exemplary process for converting an ANSI SQL query containing a GROUP BY command into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention.
- FIG. 5( b ) is a flow chart illustrating an exemplary process for converting an ANSI SQL query containing a GROUP BY and HAVING command into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention.
- FIG. 6( a ) is a flow chart illustrating an exemplary process for converting an ANSI SQL query that performs an inner equi-join into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention.
- FIG. 6( b )-( d ) each are portions of a flowchart of variations of the process of FIG. 6( a ) with FIG. 6( b ) illustrating an exemplary process for the map-reduce reducer program of an ANSI SQL query that performs a left-outer equi-join, with FIG. 6( c ) illustrating an exemplary process for the map-reduce reducer program of an ANSI SQL query that performs a right-outer equi-join, and with FIG. 6( d ) illustrating an exemplary process for the map-reduce reducer program of an ANSI SQL query that performs a full-outer equi-join, all three in accordance with one embodiment of the present invention.
- FIG. 7 is a flow chart illustrating an exemplary process for converting an ANSI SQL query containing an ORDER BY command into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention.
- FIG. 8 is a flow chart illustrating an exemplary process for converting the BCAT aggregation operator into a map-reduce program comprising two mapper programs and two reducer programs in accordance with one embodiment of the present invention.
- FIG. 1 illustrates an embodiment of the computing and data communications environment configured in accordance with the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- Each client computer system 105 1 . . . 105 N includes a network interface that enables communication with the application server 107 over network 106 .
- the network may be a local-area network where both the client system 105 and the server system 100 reside at the same general location, or there may be network connections between geographically distributed systems, including network connections over the internet.
- Client system 105 includes a central-processing unit (CPU), one or more memory units, a storage device with various applications residing there on, an input mechanism, an output mechanism, coupled by a bus and an operating system configured to manage the interaction between the computer hardware and software applications running on the client system 105 .
- CPU central-processing unit
- memory units one or more memory units
- storage device with various applications residing there on
- input mechanism an output mechanism
- an operating system configured to manage the interaction between the computer hardware and software applications running on the client system 105 .
- the server system 100 may include hardware components and an operating system similar to the client component. Accordingly, the server system generally includes one or more CPUs, one or more memory units, one or more storage devices with various applications residing there on, an input mechanism, an output mechanism coupled by a bus, and an operating system.
- the client-server configuration shown in FIG. 1 is exemplary of one configuration and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- Embodiments of the present invention may be implemented using other configurations including clusters of servers connected by a network, configurations where the server system is deployed in a grid computing architecture or a cloud computing architecture, configurations that include network storage appliances, and configurations where both the client and servers reside in a single computer system.
- GUI graphical user interface
- the client application may be configured to allow the user to compose a SQL query and submit the query to the runtime component 103 .
- the client system may transmit the SQL query to the runtime component using a Simple Object Access Protocol (SOAP) over Hypertext Transfer Protocol (HTTP).
- SOAP Simple Object Access Protocol
- HTTP server 104 e.g., open source Apache web-server program or Microsoft's Internet Information Server
- SOAP query request from the client and transmits the query to the runtime component.
- the runtime component 103 Upon receiving the SQL query from the client, the runtime component 103 generates one or more map-reduce mapper programs and one or more map-reduce reducer programs from the input SQL query and transmits these programs to the MapReduce servers 107 for execution.
- the MapReduce servers include mapper slave servers and reducer slave servers.
- the run-time component assigns the mapper programs to the mapper slaves and the reducer programs to the reducer slaves.
- the data input for the mapper programs on each mapper slave may be in local file systems 101 accessible through the network 106 or on a distributed file system 109 . In one embodiment of the present invention, when the data resides on local file systems 101 , the data is copied to distributed file system 109 to improve execution throughput. In another embodiment of the present invention, the storage device of each mapper slave server is used for the underlying physical storage of the distributed file system 109 .
- the runtime component may be configured to write query results to the to local file systems 101 , to the distributed file system 109 , or to the database of an RDBMS server 111 .
- the client can access the query results in the local file system 101 or distributed file system 109 directly through the network, and access the query results published to a database table in the RDBMS server 111 through an RDBMS client after establishing a network connection to the RDBMS server 111 .
- FIG. 2 illustrates an exemplary process of the data manipulations from input ANSI SQL query and flat files to the output result set in accordance with one embodiment of the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- a user or a software application program 202 e.g., OLAP reporting applications or data mining applications
- a 3rd party RDBMS client 201 e.g., Microsoft SQL Client
- the ANSI SQL expression is transmitted to the SQL-MapReduce database system 210 using the driver 200 that supports the Java Database Connectivity (JDBC) and Open Database Connectivity (ODBC) protocols.
- JDBC Java Database Connectivity
- ODBC Open Database Connectivity
- the connection driver 200 must be loaded into the application server running application 202 or into RDBMS client 201 .
- the SQL-MapReduce database system Upon receiving the ANSI SQL expression, the SQL-MapReduce database system runs a query parser 211 on the query and then runs an XML generator 212 that generates an XML representation of the parsed command and its arguments that may include meta data information about the data and tables.
- the XML representation is submitted to the MapReduce program generator 213 that uses that input to implement one or more mapper programs and one or more reducer programs.
- the SQL-MapReduce database system 210 then sends the mapper programs and reducer programs generated by the MapReduce program generator 213 to the runtime component 230 .
- Runtime component 230 assigns the mapper programs to mapper-slave server cluster 240 and assigns the reducer program to reducer-slave server cluster 260 .
- Mapper slave servers 241 1 ⁇ N each receive a copy of the mapper programs which they store in their local storage device.
- Reducer-slave servers 261 1 ⁇ M each receive a copy of the reducer programs which they store in their local storage device.
- Flat files are assumed to reside on the local file systems 220 of one or more servers or on storage devices.
- an application or user can request the data residing in those files to be copied to a distributed file system (DFS) that uses the underlying physical storage of the mapper slave cluster 240 .
- DFS distributed file system
- the application 202 or the user through the query interface 201 enters the CREATE TABLE command with the following syntax into the query interface 201 :
- the CREATE TABLE command is transmitted to the SQL-MapReduce database system 210 using driver 200 .
- the SQL-MapReduce database system runs a query parser 211 on the CREATE TABLE command and then runs an XML generator 212 that generates an XML representation of the parsed command and its arguments.
- the XML representation is submitted to the runtime component 230 that executes the transfer copy of data from local file systems 220 to the mapper-slave server cluster 240 .
- each mapper-slave server Upon receiving their assigned copy of the mapper programs, each mapper-slave server executes the first mapper program on the flat files.
- the files are accessible through a DFS and resides locally on the mapper slave server.
- the outputs of the mapper programs running on mapper slaves 241 1 ⁇ N are written locally to flat files 250 1 ⁇ N on the mapper-slaves' storage device.
- Reducer-slave servers 260 1 ⁇ M make remote reads of the flat files 250 1 ⁇ N and execute their first reducer programs on these files.
- the output from reducer-slaves 260 1 ⁇ M is written locally to flat files 270 1 ⁇ M on the reducer-slaves' local storage devices. Additional mapper and reducer programs are run similarly.
- the final result set 270 is a flat file that may be copied to a local file system 290 or into an RDBMS database 280 .
- RDBMS 280 To use RDBMS 280 to store the result set, the application 202 or the user through the query interface 201 creates a database link to the RDBMS server using the following command:
- the CREATE DATABASE LINK command is transmitted to the SQL-MapReducer database system using the loaded driver 200 , parsed by query parser 210 , converted into XML by XML generator 212 , and transmitted to the runtime component for execution.
- the application 202 or the user through the query interface 201 can issue the following command to instruct the system to insert the result set into an existing table in the RDBMS server:
- the result set in the local file systems 290 or RDBMS 280 is accessible to application 202 and to the user through either the command line interface or query interface 201 .
- FIG. 3 is a flow chart illustrating an exemplary process for converting an ANSI SQL query into a map-reduce program, running said program on a distributed file system and storing the output in the same file system in accordance with one embodiment of the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- ANSI SQL expression 301 can be expressed in the following recursive grammar:
- ANSI SQL expression 301 is converted to one or map-reduce mapper programs and one or more map-reduce reducer programs 303 .
- the mapper programs and the reducer programs are executed on data residing in a distributed file system 305 and the result set is written back to the same distributed file system 307 .
- mapper programs and the reducer programs are executed on data residing in local file systems.
- the result set is written back to local file systems or to the database of an RDBMS server.
- FIG. 4 is a flow chart illustrating an exemplary process for converting a select-where ANSI SQL query into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- this figure depicts functional steps in a particular order and depicts a select-where ANSI SQL expression of a particular type, both for purposes of illustration, the process is not limited to this particular order or arrangement of steps, and nor is it limited to the specific form of the ANSI SQL expression.
- One skilled in the art will appreciate that the various steps portrayed in this figure could be rearranged, combined and/or adapted in various ways, and the ANSI SQL expression in this figure could be rewritten in various ways that are adherent to the ANSI standard.
- a 1 , . . . , a k denote one or more column names in a table ⁇ table> and ⁇ condition> denotes a predicate expression composed of column names and SQL operators.
- a select-where ANSI SQL query arrives as input ( 401 )
- the column names, the table name and the predicate expression are parsed ( 403 ).
- the predicate expression the column names contained in that expression are parsed, the operators contained in that expression are parsed, and the expression is stored in postfix notation.
- the column indices i 1 , . . . , ik corresponding to the columns a 1 , . . . , a k and the indices of any additional columns parsed from the predicate expression in step 403 are identified ( 405 ) using the schema corresponding to ⁇ table> created by the CREATE TABLE command when ⁇ table> was created.
- the map-reduce mapper program is implemented in accordance to the following sequence of steps: if the predicate expression ⁇ condition> evaluates to 1 then (i) set the mapper key to 1; (ii) set the mapper value to the list of column values stored in column indices i 1 , . . . , ik.
- step 409 the map-reduce reducer program is implemented by setting the output of the reducer to the list of values returned by the mappers.
- the map-reduce mapper program is implemented in accordance to the following sequence of steps: (i) set the mapper key to the evaluation of the predicate expression ⁇ condition>; and (ii) set the mapper value to the list of column values stored in column indices i 1 , . . . , ik
- the reducer program outputs the list of values returned by the mappers only when the key equals 1.
- the map-reduce mapper in step 407 is now implemented in accordance to the following sequence of steps: (i) set the mapper key to 1; and (ii) set the mapper value to the list of column values stored in column indices i 1 , . . . , ik.
- ⁇ table> refers to multiple table names each with its own schema that is used in step 405 .
- FIG. 5( a ) is a flow chart illustrating an exemplary process for converting an ANSI SQL query containing a GROUP BY command into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- this figure depicts functional steps in a particular order and depicts an ANSI SQL expression containing the GROUP BY command of a particular type, both for purposes of illustration, the process is not limited to this particular order or arrangement of steps, and nor is it limited to the particular type of ANSI SQL expression.
- One skilled in the art will appreciate that the various steps portrayed in this figure could be rearranged, combined and/or adapted in various ways, and the ANSI SQL expression in this figure could be rewritten in various ways that are adherent to the ANSI standard.
- a 1 , . . . , a k denote one or more column names in a table ⁇ table> on which the GROUP BY command operates;
- b 1 , . . . , b j denote one or more column names in the table ⁇ table> on which the aggregate functions f 1 , . . . , f j operate;
- (iii) and ⁇ condition> denotes a predicate expression composed of column names and SQL operators.
- the aggregate functions f 1 , . . . , f j are commutative and associative functions such as COUNT, SUM, PROD, MAX, MIN . Other functions such as AVG are computed by using SUM and COUNT .
- the column indices i 1 , . . . , ik corresponding to the GROUP BY columns a 1 , . . . , a k , the column indices e 1 , . . . , ej corresponding to the aggregation columns b 1 , . . . , b j and the indices of any additional columns parsed from the predicate expression in step 503 are identified ( 505 ) using the schema corresponding to ⁇ table> created by the CREATE TABLE command when ⁇ table> was created.
- step 507 the map-reduce mapper program is implemented in accordance to the following sequence of steps: if the predicate expression ⁇ condition> evaluates to 1 then (i) set the mapper key to the list of column values stored in the GROUP BY columns indexed i 1 , . . . , ik;; and (ii) set the mapper value to the list of column values stored in aggregation column indices e 1 , . . . , ej.
- step 509 the map-reduce reducer program is implemented in accordance to the following sequence of steps: for each key returned by the mapper program (i) initialize the values of the aggregate functions f 1 , . . . , f j to x 1 , . . . , x j where said initialization depends on the type of function as follows: for COUNT initialize to zero; for SUM initialize to zero; for PROD initialize to 1; for MAX initialize to the minimum machine integer or float in the system (depending on the column data type); for MIN initialize to the maximum machine integer or float in the system; (ii) for each value in the list of values returned by the mapper, get that value (ve 1 , . . .
- FIG. 5( b ) is a flow chart illustrating an exemplary process for converting an ANSI SQL query containing a GROUP BY command and a HAVING command into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- this figure depicts functional steps in a particular order and depicts an ANSI SQL expression containing the GROUP BY and HAVING commands of a particular type, both for purposes of illustration, the process is not limited to this particular order or arrangement of steps, and nor is it limited to the particular type of ANSI SQL expression.
- One skilled in the art will appreciate that the various steps portrayed in this figure could be rearranged, combined and/or adapted in various ways, and the ANSI SQL expression in this figure could be rewritten in various ways that are adherent to the ANSI standard.
- a 1 , . . . , a k denote one or more column names in a table ⁇ table> on which the GROUP BY command operates;
- b 1 , . . . , b k denote one or more column names in the table ⁇ table> on which the aggregate functions f 1 , . . . , f j operate;
- ⁇ condition a > denotes a predicate expression composed of column names and SQL operators; and
- ⁇ condition b > denotes the predicate for the HAVING command.
- step 519 the map-reduce reducer program is implemented in accordance to the following sequence of steps: for each key returned by the mapper program (i) initialize the values of the aggregate functions f 1 , . . . , f j to x 1 , . . . , x j where said initialization depends on the type of function as follows: for COUNT initialize to zero; for SUM initialize to zero; for PROD initialize to 1; for MAX initialize to the minimum machine integer in the system; for MIN initialize to the maximum machine integer in the system; (ii) for each value in the list of values returned by the mapper, get that value (v e1 , . . .
- map-reduce mapper in step 507 is now implemented in accordance to the following sequence of steps: (i) set the mapper key to the list of column values stored in the GROUP BY columns indexed i 1 , . . . , ik; and (ii) set the mapper value to the list of column values stored in aggregation column indices e 1 , . . . , ej.
- the map-reduce mapper in step 507 is now implemented in accordance to the following sequence of steps: (i) set the mapper key to the list of column values stored in the GROUP BY columns indexed i 1 , . . . , ik;; and (ii) set the mapper value to 1. Furthermore, the map-reduce reducer in step 509 of FIG. 5( a ) is now implemented in accordance to the following sequence of steps: for each key returned by the mapper program, output the key.
- ⁇ table> refers to multiple table names each with its own schema that is used in step 505 .
- FIG. 5( a ) for converting an ANSI SQL query containing a GROUP BY command into a map-reduce program can be used to convert an ANSI SQL query containing a DISTINCT command.
- an ANSI SQL expression containing a DISTINCT command can be reduced to an expression that uses a GROUP BY command.
- FIG. 6 is a flow chart illustrating an exemplary process for converting an ANSI SQL query that performs an inner equi-join into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- this figure depicts functional steps in a particular order and depicts an inner equi-join ANSI SQL expression of a particular type, both for purposes of illustration, the process is not limited to this particular order or arrangement of steps, and nor is it limited to the specific form of the ANSI SQL expression.
- One skilled in the art will appreciate that the various steps portrayed in this figure could be rearranged, combined and/or adapted in various ways, and the ANSI SQL expression in this figure could be rewritten in various ways that are adherent to the ANSI standard.
- A.a 1 , . . . , A. ak denote one or more column names in a table ⁇ table a >
- B.b 1 , . . . , B. bj denote one or more column names in a table ⁇ table b >
- ⁇ condition a > denotes a predicate expression composed of column names from ⁇ table a >
- ⁇ condition b > denotes a predicate expression composed of column names from ⁇ table b >
- ⁇ condition ab > denotes an equi-join predicate expression composed of column names from ⁇ table a > and ⁇ table b >.
- step 609 the map-reduce mapper program is implemented in accordance to the following sequence of steps: if in processing ⁇ table a ,> the predicate expression ⁇ condition a ,> evaluates to 1 then (i) set the mapper key to the list of table A column values at indices g 1 , . . . , gp; (ii) set the mapper value to the list of column values stored in column indices i 1 , . . .
- step 611 the map-reduce reducer program is implemented in accordance to the following sequence of steps: for each key returned by the mapper program (i) initialize lists list a and list b to empty; (ii) for each value in the list of values returned by the mapper, read the first token and if it matches A then add the remaining elements in the value to list a , else add them to list b ; (iii) after iterating over the entire list of values in (ii), if both list a , and list b are not empty then output the cross-product of these two lists.
- the process illustrated in FIG. 6( a ) enables the input SQL expression to represent a self-join by using table aliases in the expression. Replacing a nested query by a self-join query has better execution performance because it only needs to run a single MapReduce job rather than separate jobs for each nested query.
- a SQL expression for a left outer equi-join over two tables is implemented as illustrated in FIG. 6( a ) with the map-reduce reducer program in step 611 implemented in accordance to the following sequence of steps illustrated in FIG. 6( b ) step 613 : for each key returned by the mapper program (i) initialize lists list a , and list b to empty; (ii) for each value in the list of values returned by the mapper, read the first token and if it matches A then add the remaining elements in the value to list a , else add them to list b ; (iii) after iterating over the entire list of values in (ii), if list a , is non-empty then output the cross-product of these two lists.
- a SQL expression for a right outer equi-join over two tables is implemented as illustrated in FIG. 6( a ) with the map-reduce reducer program in step 611 implemented in accordance to the following sequence of steps illustrated in FIG. 6( c ) step 615 : for each key returned by the mapper program (i) initialize lists list a , and list b to empty; (ii) for each value in the list of values returned by the mapper, read the first token and if it matches A then add the remaining elements in the value to list a , else add them to list b ; (iii) after iterating over the entire list of values in (ii), if list b is non-empty then output the cross-product of these two lists.
- a SQL expression for a full outer equi-join over two tables is implemented as illustrated in FIG. 6( a ) with the map-reduce reducer program in step 611 implemented in accordance to the following sequence of steps illustrated in FIG. 6( d ) step 617 : for each key returned by the mapper program (i) initialize lists list a and list b to empty; (ii) for each value in the list of values returned by the mapper, read the first token and if it matches A then add the remaining elements in the value to list a , else add them to list b ; (iii) after iterating over the entire list of values in (ii) output the cross-product of these two lists.
- a SQL expression for equi-joins (inner or any of the outer) over three or more tables can be reduced to a nested SQL expression where each nested expression is an (inner, left-outer, right-outer, or full-outer) equi-join over two tables and can be implemented by one of the processes illustrated in FIGS. 6( a )-( d ).
- the equi-join SQL expression in step 601 is in the “implicit join notation”.
- an equi-join expression in the “explicit join notation” that uses one of the following ANSI SQL command JOIN ⁇ table> ON, INNER JOIN ⁇ table> ON, LEFT JOIN ⁇ table> ON, RIGHT JOIN ⁇ table> ON, FULL JOIN ⁇ table> ON to express an inner join, left-outer join, right-outer join, or full join can be implemented by one of the processes illustrated in FIG. 6( a )-( d ).
- FIG. 7 is a flow chart illustrating an exemplary process for converting an ANSI SQL query containing an ORDER BY command into a map-reduce program comprising one mapper program and one reducer program in accordance with one embodiment of the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- this figure depicts functional steps in a particular order and depicts an ANSI SQL expression containing the ORDER BY command of a particular type, both for purposes of illustration, the process is not limited to this particular order or arrangement of steps, and nor is it limited to the particular type of ANSI SQL expression.
- One skilled in the art will appreciate that the various steps portrayed in this figure could be rearranged, combined and/or adapted in various ways, and the ANSI SQL expression in this figure could be rewritten in various ways that are adherent to the ANSI standard.
- a i , . . . , a k denote one or more column names in a table ⁇ table> on which the SELECT command operates; and (ii) b i , . . . , b j denote one or more column names in the table ⁇ table> on which the ORDER BY command operates.
- the column indices i 1 , . . . , ik corresponding to the columns a i , . . . , a k and the column indices e 1 , . . . , ej corresponding to the ORDER BY command parsed in step 603 are identified ( 705 ) using the schema corresponding to ⁇ table> created by the CREATE TABLE command when ⁇ table> was created.
- the map-reduce mapper program is implemented in accordance to the following sequence of steps: (i) set the mapper key to the list of column values stored in the ORDER BY columns indexed i 1 , . . . , ik; (ii) set the mapper value to the list of column values stored in the column indices e 1 , . . . , ej.
- step 709 the map-reduce reducer program is implemented in accordance to the following sequence of steps: for each key returned by the mapper program and for each value in the list of values returned by the mapper, output the value.
- FIG. 8 is a flow chart illustrating an exemplary process for converting the BCAT aggregate operator into a map-reduce program comprising two mapper programs and two reducer programs in accordance with one embodiment of the present invention and is not intended to limit scope as one of ordinary skill would understand on review of this application that other configurations could be utilized without departing from the claimed invention.
- this figure depicts functional steps in a particular order and depicts an ANSI SQL expression containing the BCAT operator of a particular type, both for purposes of illustration, the process is not limited to this particular order or arrangement of steps, and nor is it limited to the particular type of ANSI SQL expression.
- One skilled in the art will appreciate that the various steps portrayed in this figure could be rearranged, combined and/or adapted in various ways, and the ANSI SQL expression in this figure could be rewritten in various ways that are adherent to the ANSI standard.
- a i , . . . , ak denote one or more column names in a table ⁇ table> on which the BCAT command operates;
- b i denote a column name in the table ⁇ table> on which the aggregate function BCAT operates.
- the column indices i 1 , . . . , ik corresponding to the GROUP BY columns a 1 , . . . , a k and the column index e 1 corresponding to the aggregation column b 1 are identified ( 805 ) using the schema corresponding to ⁇ table> created by the CREATE TABLE command when ⁇ table> was created.
- the map-reduce mapper program is implemented in accordance to the following sequence of steps: (i) set the mapper key to the list of column values stored in the GROUP BY columns indexed i 1 , . . . , ik, (ii) set the mapper value to the list of column values stored in aggregation column indices e 1 .
- step 809 the map-reduce reducer program is implemented in accordance to the following sequence of steps: for each key returned by the mapper program (i) initialize the value x of the aggregate function BCAT to the empty set; (ii) for each value in the list of values returned by the mapper, get that value v e1 , corresponding to the column value in index position e 1 and append (or concatenate) it to x; (iii) after iterating over the entire list of values in (ii), output x and the current key.
- Example log file contains 20 records as shown above which is stored as two files of 10 records each in a distributed file system.
- the present invention is configured with 2 mapper-slave processes and two reducer-slave processes.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
Description
SELECT path, COUNT(path), SUM(pathRevenue) FROM |
(SELECT sessionID, BCAT (nodeID) AS path, SUM(revenue) AS |
pathRevenue |
FROM (SELECT sessionID, nodeID FROM <weblog table> ORDER BY |
timeID) |
GROUP BY sessionID) |
GROUP BY path |
CREATE TABLE <table name> (<column name><data type>[, <column |
name><data type>,...]) |
COLUMN SEP <string>[DFS PATH <DFS path>][IMPORT |
DATA FROM <local path>][COMMENT <string>] |
-
- where in this syntax, expressions enclosed by < >are inputs and expressions enclosed by [ ] are optional. In the above operator, (i) the column name and data types defines the table schema; (ii) the string value of the
COLUMN SEP defines the string used to delimit the fields in the data files; (iii) the DFS PATH clause instructs the system to copy the data into that directory in the DFS or to create a new one when that clause is not specified; (iv) theIMPORT DATA FROM clause instructs the system to copy files from the specified location in the local file system; and (v) theCOMMENT clause is used to associate a comment with the table at creation.
- where in this syntax, expressions enclosed by < >are inputs and expressions enclosed by [ ] are optional. In the above operator, (i) the column name and data types defines the table schema; (ii) the string value of the
CREATE DATABASE LINK <link name> |
CONNECTION URL <connection url for rdbms> |
DRIVER <rdbms driver class name> [ USER <username> PASSWORD |
<password> ][ property val, ... ] |
-
- For example, to make a link to the SQL server database provided by Microsoft, the user runs the following command:
CREATE DATABASE LINK sqlserverlink CONNECTION URL | ||
‘jdbc:sqlserver://yourhost:8888;user=user;password=password; | ||
databaseName = yourdatabase’ | ||
DRIVER ‘com.microsoft.sqlserver.jdbc.SQLServerDriver’ | ||
-
- For example, if the user created the preceding SQL database link, sqlserverlink, then the following command
INSERT INTO mytable@sqlserverlink SELECT FirstName, LastName |
FROMnametable |
-
- would insert result set 270 corresponding to the following query
- SELECT FirstName, LastName FROM nametable
- into the RDBMS table mytable in
RDBMS 280.
SELECT [ DISTINCT ][ TOP n]<select list> [INTO <into element>] | ||
FROM <element> [ AS <alias> ](, <element> [ AS <alias> ] )* | ||
[ WHERE <condition> ] [ GROUP BY <group | ||
by list> ] [ HAVING <condition> ] | ||
[ORDER BY <order by list>] | ||
-
- where (i) <select list> is a comma-separated list of column names selected from the <element> inputs in the SQL expression or is a mathematical expression with column name inputs; (ii) <element> is either a table name <table> or an ANSI SQL subquery enclosed in parenthesis ( ); (iii) <into element> is a table name; (iv) <group by list> is a comma-separated list of column names selected from the <element> inputs in the SQL expression; (v) <order by list> is a comma-separated list of column names selected from the <element> inputs; (vi) <condition> is a boolean expression.
-
-
SELECT DISTINCT ai, . . . , akFROM <table> - is equivalent to the following SQL expression
-
SELECT a1, . . . , akFROM <table>GROUP BY a1, . . . , ak
-
Column name | Data Type | ||
Header | VARCHAR | ||
SearchString | VARCHAR | ||
Listings | INT | ||
PartnerID | VARCHAR | ||
Date | DATETIME format ‘MM/dd/yy’ | ||
ListingID | BIGINT | ||
NWUUID | VARCHAR | ||
Column delimiter- ‘|’ |
A sample (20 records) of network search log file that constitute the contents of NWSearchLogs table is shown below:
INFO - search|computer repair|4|6547316|05/31/08|002344458|nwuuid-6547316- |
268AEB49-7654-8924-6EC9-880419BFEF02-ym |
INFO - search|moving vehicles|3|6547318|05/31/08|010043286|nwuuid-6547318- |
7970219D-CAD6-9779-582E-5E87BE116E0-ym |
INFO - search|private equity|3|ft1|05/31/08|000000036|nwuuid-ft1-5D5C5751-DF3B- |
607D-CD92-C1E7E060DDB1-ym |
INFO - search|trailer rentals|6|6547318|05/31/08|000000692|nwuuid-6547318- |
B77BF70D-90D9-65F1-D551-D08F8F980CAA-ym |
INFO - search|computer repair|4|6547316|05/31/08|000033286|nwuuid-6547316- |
7F2DD98C-0703-5A2D-9BA2-DAE15CDD3D77-ym |
INFO - search|email marketing|1|7001200|05/31/08|000000817|nwuuid-7001200- |
B51E5788-32EF-807F-DB26-EF42CA7DC35D-ym |
INFO - search|private equity|6|8559099|05/31/08|000000942|nwuuid-8559099- |
A0841A51-0820-55B7-6B5D-371F08ED3D10-ym |
INFO - search|computer repair|1|6547316|05/31/08|000001130|nwuuid-6547316- |
A7444F37-A16C-6D29-3DE7-7FBB5D14A766-ym |
INFO - search|medical clinics|2|6547316|05/30/08|000001599|nwuuid-6547316- |
9721EBC1-2700-3F75-800B-601B708B4090-ym |
INFO - search|private equity|3|ft1|05/30/08|002002099|nwuuid-ft1-AC335881-2738- |
A707-D88C-D22184331D77-ym |
INFO - search|private equity|3|ft1|05/31/08|002002099|nwuuid-ft1-AC335881-2738- |
A707-D88C-D22184331D77-ym |
INFO - search|email marketing|1|7001200|05/31/08|000015880|nwuuid-7001200- |
F1DCE080-C4A8-C3C7-1E46-0F2B490399C2-ym |
INFO - search|blue tooth|1|8559099|05/31/08|000001802|nwuuid-8559099-9E13356C- |
3635-A631-96A3-249EFED9F855-ym |
INFO - search|dedicated server hosting|1|7001200|05/31/08|000002989|nwuuid- |
7001200-D0EDDBDF-A47D-88BB-01C7-159AC3549FB6-ym |
INFO - search|blue tooth|1|8559099|05/31/08|000001802|nwuuid-8559099-9E13356C- |
3635-A631-96A3-249EFED9F855-ym |
INFO - search|private equity|3|ft1|05/30/08|002002099|nwuuid-ft1-AC335881-2738- |
A707-D88C-D22184331D77-ym |
INFO - search|dedicated server hosting|1|7001200|05/31/08|000003630|nwuuid- |
7001200-C781224A-3574-B559-8985-26167DBF4EA4-ym |
INFO - search|financial planning|10|6547318|05/31/08|000003864|nwuuid-6547318- |
CC031E3C-9ED7-1778-2A3A-58B2F6C3EBD4-ym |
INFO - search|email|8|internet|05/30/08|000003942|nwuuid-internet-BAD13AE6-B90B- |
E015-013A-9B91911358B0-ym |
INFO - search|wireless network|6|8559099|05/30/08|000004036|nwuuid-8559099- |
BC244F67-890D-0866-6D75-645EA8FB4D6B-ym |
Problem Description: Find all the distinct search strings used by users on May 31, 2008 from network search logs.
Input ANSI SQL Command:
SELECT DISTINCT SearchString FROM NWSearchLogs WHERE date=‘May 31, 2008’
Example log file contains 20 records as shown above which is stored as two files of 10 records each in a distributed file system. In this illustration, the present invention is configured with 2 mapper-slave processes and two reducer-slave processes.
Mapper 1 | Mapper 2 |
Input Records: 10 | Input Records: 10 |
INFO - search|computer | INFO - search|private |
repair|4|6547316|05/31/08|002344458|nwuuid- | equity|3|ft1|05/31/08|002002099|nwuuid-ft1- |
6547316-268AEB49-7654-8924-6EC9-880419BFEF02- | AC335881-2738-A707-D88C-D22184331D77-ym |
ym | INFO - search|email |
INFO - search|moving | marketing|1|7001200|05/31/08|000015880|nwuuid- |
vehicles|3|6547318|05/31/08|010043286|nwuuid- | 7001200-F1DCE080-C4A8-C3C7-1E46-0F2B490399C2-ym |
6547318-7970219D-CAD6-9779-582E-5E87BE116CE0- | INFO - search|blue |
ym | tooth|1|8559099|05/31/08|000001802|nwuuid-8559099- |
INFO - search|private | 9E13356C-3635-A631-96A3-249EFED9F855-ym |
equity|3|ft1|05/31/08|000000036|nwuuid-ft1- | INFO - search|dedicated server |
5D5C5751-DF3B-607D-CD92-C1E7E060DDB1-ym | hosting|1|7001200|05/31/08|000002989|nwuuid- |
INFO - search|trailer | 7001200-D0EDDBDF-A47D-88BB-01C7-159AC3549FB6-ym |
rentals|6|6547318|05/31/08|000000692|nwuuid- | INFO - search|blue |
6547318-B77BF70D-90D9-65F1-D551-D08F8F980CAA- | tooth|1|8559099|05/31/08|000001802|nwuuid-8559099- |
ym | 9E13356C-3635-A631-96A3-249EFED9F855-ym |
INFO - search|computer | INFO - search|private |
repair|4|6547316|05/31/08|000033286|nwuuid- | equity|3|ft1|05/30/08|002002099|nwuuid-ft1- |
6547316-7F2DD98C-0703-5A2D-9BA2-DAE15CDD3D77- | AC335881-2738-A707-D88C-D22184331D77-ym |
ym | INFO - search|dedicated server |
INFO - search|email | hosting|1|7001200|05/31/08|000003630|nwuuid- |
marketing|1|7001200|05/31/08|000000817|nwuuid- | 7001200-C781224A-3574-B559-8985-26167DBF4EA4-ym |
7001200-B51E5788-32EF-807F-DB26-EF42CA7DC35D- | INFO - search|financial |
ym | planning|10|6547318|05/31/08|000003864|nwuuid- |
INFO - search|private | 6547318-CC031E3C-9ED7-1778-2A3A-58B2F6C3EBD4-ym |
Equity|6|8559099|05/31/08|000000942|nwuuid- | INFO - |
8559099-A0841A51-0820-55B7-6B5D-371F08ED3D10- | search|email|8|internet|05/30/08|000003942|nwuuid- |
ym | internet-BAD13AE6-B90B-E015-013A-9B91911358B0-ym |
INFO - search|computer | INFO - search|wireless |
repair|1|6547316|05/31/08|000001130|nwuuid- | network|6|8559099|05/30/08|000004036|nwuuid- |
6547316-A7444F37-A16C-6D29-3DE7-7FBB5D14A766- | 8559099-BC244F67-890D-0866-6D75-645EA8FB4D6B-ym |
ym | |
INFO - search|medical | |
clinics|2|6547316|05/30/08|000001599|nwuuid- | |
6547316-9721EBC1-2700-3F75-800B-601B708B4090- | |
ym | |
INFO - search|private | |
Equity|3|ft1|05/30/08|002002099|nwuuid-ft1- | |
AC335881-2738-A707-D88C-D22184331D77-ym | |
Filter Records | Filter Records |
using WHERE clause | using WHERE clause |
INFO - search|computer | INFO - search|private |
repair|4|6547316|05/31/08|002344458|nwuuid- | equity|3|ft1|05/31/08|002002099|nwuuid-ft1- |
6547316-268AEB49-7654-8924-6EC9-880419BFEF02- | AC335881-2738-A707-D88C-D22184331D77-ym |
ym | INFO - search|email |
INFO - search|moving | marketing|1|7001200|05/31/08|000015880|nwuuid- |
vehicles|3|6547318|05/31/08|010043286|nwuuid- | 7001200-F1DCE080-C4A8-C3C7-1E46-0F2B490399C2- |
6547318-7970219D-CAD6-9779-582E-5E87BE116CE0- | ym |
ym | INFO - search|blue |
INFO - search|private | tooth|1|8559099|05/31/08|000001802|nwuuid- |
equity|3|ft1|05/31/08|000000036|nwuuid-ft1- | 8559099-9E13356C-3635-A631-96A3-249EFED9F855- |
5D5C5751-DF3B-607D-CD92-C1E7E060DDB1-ym | ym |
INFO - search|trailer | INFO - search|dedicated server |
rentals|6|6547318|05/31/08|000000692|nwuuid- | hosting|1|7001200|05/31/08|000002989|nwuuid- |
6547318-B77BF70D-90D9-65F1-D551-D08F8F980CAA- | 7001200-D0EDDBDF-A47D-88BB-01C7-159AC3549FB6- |
ym | ym |
INFO - search|computer | INFO - search|blue |
repair|4|6547316|05/31/08|000033286|nwuuid- | tooth|1|8559099|05/31/08|000001802|nwuuid- |
6547316-7F2DD98C-0703-5A2D-9BA2-DAE15CDD3D77- | 8559099-9E13356C-3635-A631-96A3-249EFED9F855- |
ym | ym |
INFO - search|email | INFO - search|private |
marketing|1|7001200|05/31/08|000000817|nwuuid- | equity|3|ft1|05/30/08|002002099|nwuuid-ft1- |
7001200-B51E5788-32EF-807F-DB26-EF42CA7DC35D- | AC335881-2738-A707-D88C-D22184331D77-ym |
ym | INFO - search|dedicated server |
INFO - search|private | hosting|1|7001200|05/31/08|000003630|nwuuid- |
equity|6|8559099|05/31/08|000000942|nwuuid- | 7001200-C781224A-3574-B559-8985-26167DBF4EA4- |
8559099-A0841A51-0820-55B7-6B5D-371F08ED3D10- | ym |
ym | INFO - search|financial |
INFO - search|computer | planning|10|6547318|05/31/08|000003864|nwuuid- |
repair|1|6547316|05/31/08|000001130|nwuuid- | 6547318-CC031E3C-9ED7-1778-2A3A-58B2F6C3EBD4- |
6547316-A7444F37-A16C-6D29-3DE7-7FBB5D14A766- | ym |
ym | |
Output (Key, Value) pairs | Output (Key, Value) pairs |
Mapper 1 | Mapper 2 |
(Key, Value) pairs | (Key, Value) pairs |
Key | Value | Key | Value |
computer repair | 1 | private equity | 1 |
moving vehicles | 1 | email marketing | 1 |
private equity | 1 | blue tooth | 1 |
trailer rentals | 1 | dedicated server hosting | 1 |
computer repair | 1 | blue tooth | 1 |
email marketing | 1 | private equity | 1 |
private equity | 1 | dedicated server hosting | 1 |
computer repair | 1 | financial planning | 1 |
Value fields is irrevalent here, so outputting 1 |
Reducer 1 | Reducer 2 |
Key | List of Values | Key | List of Values |
computer repair | [1, 1, 1] | private equity | [1, 1] |
moving vehicles | [1] | email marketing | [1] |
private equity | [1, 1] | blue tooth | [1, 1] |
trailer rentals | [1] | dedicated server hosting | [1, 1] |
email marketing | [1] | financial planning | [1] |
Output (Key, Value) pairs | Output (Key, Value) pairs |
Key | Value | Key | Value |
computer repair | 1 | private equity | 1 |
moving vehicles | 1 | email marketing | 1 |
private equity | 1 | blue tooth | 1 |
trailer rentals | 1 | dedicated server hosting | 1 |
email marketing | 1 | financial planning | 1 |
Sort on Keys | Sort on Keys |
Key | Value | Key | Value |
computer repair | 1 | blue tooth | 1 |
email marketing | 1 | dedicated server hosting | 1 |
moving vehicles | 1 | email marketing | 1 |
private equity | 1 | financial planning | 1 |
trailer rentals | 1 | private equity | 1 |
Reducer(s) |
Key | List of Values |
blue tooth | [1] |
computer repair | [1] |
dedicated server hosting | [1] |
email marketing | [1, 1] |
financial planning | [1] |
moving vehicles | [1] |
private equity | [1, 1] |
trailer rentals | [1] |
Output (Key, Value) pairs |
Key | Value |
blue tooth | NULL |
computer repair | NULL |
dedicated server hosting | NULL |
email marketing | NULL |
financial planning | NULL |
moving vehicles | NULL |
private equity | NULL |
trailer rentals | NULL |
Output file |
blue tooth | ||
computer repair | ||
dedicated server hosting | ||
email marketing | ||
financial planning | ||
moving vehicles | ||
private equity | ||
trailer rentals | ||
Claims (11)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/249,780 US7917463B2 (en) | 2008-10-10 | 2008-10-10 | System and method for data warehousing and analytics on a distributed file system |
PCT/US2009/033623 WO2010042238A1 (en) | 2008-10-10 | 2009-02-10 | System and method for data warehousing and analytics on a distributed file system |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/249,780 US7917463B2 (en) | 2008-10-10 | 2008-10-10 | System and method for data warehousing and analytics on a distributed file system |
Publications (2)
Publication Number | Publication Date |
---|---|
US20090055370A1 US20090055370A1 (en) | 2009-02-26 |
US7917463B2 true US7917463B2 (en) | 2011-03-29 |
Family
ID=40383102
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/249,780 Active 2029-11-25 US7917463B2 (en) | 2008-10-10 | 2008-10-10 | System and method for data warehousing and analytics on a distributed file system |
Country Status (2)
Country | Link |
---|---|
US (1) | US7917463B2 (en) |
WO (1) | WO2010042238A1 (en) |
Cited By (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050038782A1 (en) * | 2003-05-27 | 2005-02-17 | Styles Michael E. | System and method of summary filter transformation |
US20070150436A1 (en) * | 2005-12-22 | 2007-06-28 | Oracle International Corporation | Query generator |
US20100175049A1 (en) * | 2009-01-07 | 2010-07-08 | Microsoft Corporation | Scope: a structured computations optimized for parallel execution script language |
US20100257198A1 (en) * | 2009-04-02 | 2010-10-07 | Greeenplum, Inc. | Apparatus and method for integrating map-reduce into a distributed relational database |
US20100313205A1 (en) * | 2009-06-09 | 2010-12-09 | Yahoo! Inc., A Delaware Corporation | System and method for offline data generation for online system analysis |
WO2013070873A1 (en) * | 2011-11-10 | 2013-05-16 | Treasure Data, Inc. | System and method for operating a big-data platform |
US9317542B2 (en) | 2011-10-04 | 2016-04-19 | International Business Machines Corporation | Declarative specification of data integration workflows for execution on parallel processing platforms |
US9418085B1 (en) | 2013-03-13 | 2016-08-16 | Amazon Technologies, Inc. | Automatic table schema generation |
US9639407B1 (en) * | 2014-12-09 | 2017-05-02 | Parallel Machines Ltd. | Systems and methods for efficiently implementing functional commands in a data processing system |
US10282181B2 (en) | 2013-12-06 | 2019-05-07 | Ab Initio Technology Llc | Source code translation |
US20190317782A1 (en) * | 2010-05-04 | 2019-10-17 | Google Llc | Parallel Processing of Data |
US11093223B2 (en) | 2019-07-18 | 2021-08-17 | Ab Initio Technology Llc | Automatically converting a program written in a procedural programming language into a dataflow graph and related systems and methods |
US11455287B1 (en) * | 2012-08-01 | 2022-09-27 | Tibco Software Inc. | Systems and methods for analysis of data at disparate data sources |
Families Citing this family (49)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6912528B2 (en) * | 2000-01-18 | 2005-06-28 | Gregg S. Homer | Rechargeable media distribution and play system |
US8214324B2 (en) * | 2009-08-25 | 2012-07-03 | International Business Machines Corporation | Generating extract, transform, and load (ETL) jobs for loading data incrementally |
US8321454B2 (en) * | 2009-09-14 | 2012-11-27 | Myspace Llc | Double map reduce distributed computing framework |
US9619291B2 (en) * | 2009-12-20 | 2017-04-11 | Yahoo! Inc. | System and method for a task management library to execute map-reduce applications in a map-reduce framework |
US9665620B2 (en) | 2010-01-15 | 2017-05-30 | Ab Initio Technology Llc | Managing data queries |
US8874600B2 (en) * | 2010-01-30 | 2014-10-28 | International Business Machines Corporation | System and method for building a cloud aware massive data analytics solution background |
US8935232B2 (en) * | 2010-06-04 | 2015-01-13 | Yale University | Query execution systems and methods |
US9495427B2 (en) | 2010-06-04 | 2016-11-15 | Yale University | Processing of data using a database system in communication with a data processing framework |
US9336263B2 (en) | 2010-06-04 | 2016-05-10 | Yale University | Data loading systems and methods |
US11726955B2 (en) | 2010-06-19 | 2023-08-15 | Hewlett Packard Enterprise Development Lp | Methods and apparatus for efficient container location database snapshot operation |
US9323775B2 (en) | 2010-06-19 | 2016-04-26 | Mapr Technologies, Inc. | Map-reduce ready distributed file system |
US8775425B2 (en) * | 2010-08-24 | 2014-07-08 | International Business Machines Corporation | Systems and methods for massive structured data management over cloud aware distributed file system |
US8260803B2 (en) * | 2010-09-23 | 2012-09-04 | Hewlett-Packard Development Company, L.P. | System and method for data stream processing |
US8438153B2 (en) * | 2010-10-11 | 2013-05-07 | Hewlett-Packard Development Company, L.P. | Performing database joins |
CN102480512B (en) | 2010-11-29 | 2015-08-12 | 国际商业机器公司 | For the method and apparatus of expansion servers end disposal ability |
US9307048B2 (en) | 2010-12-28 | 2016-04-05 | Microsoft Technology Licensing, Llc | System and method for proactive task scheduling of a copy of outlier task in a computing environment |
US10311105B2 (en) * | 2010-12-28 | 2019-06-04 | Microsoft Technology Licensing, Llc | Filtering queried data on data stores |
US9116955B2 (en) | 2011-05-02 | 2015-08-25 | Ab Initio Technology Llc | Managing data queries |
WO2013009503A2 (en) | 2011-07-08 | 2013-01-17 | Yale University | Query execution systems and methods |
CN102426609B (en) * | 2011-12-28 | 2013-02-13 | 厦门市美亚柏科信息股份有限公司 | Index generation method and index generation device based on MapReduce programming architecture |
TWI475411B (en) * | 2011-12-29 | 2015-03-01 | Chunghwa Telecom Co Ltd | Large data checking system and its method in cloud platform |
US9262216B2 (en) | 2012-02-14 | 2016-02-16 | Microsoft Technologies Licensing, LLC | Computing cluster with latency control |
CN103377269B (en) * | 2012-04-27 | 2016-12-28 | 国际商业机器公司 | Sensing data localization method and device |
US8516008B1 (en) | 2012-05-18 | 2013-08-20 | Splunk Inc. | Flexible schema column store |
US10061807B2 (en) | 2012-05-18 | 2018-08-28 | Splunk Inc. | Collection query driven generation of inverted index for raw machine data |
US8682925B1 (en) | 2013-01-31 | 2014-03-25 | Splunk Inc. | Distributed high performance analytics store |
CN102799622B (en) * | 2012-06-19 | 2015-07-15 | 北京大学 | Distributed structured query language (SQL) query method based on MapReduce expansion framework |
US8788525B2 (en) | 2012-09-07 | 2014-07-22 | Splunk Inc. | Data model for machine data for semantic search |
US20150019537A1 (en) | 2012-09-07 | 2015-01-15 | Splunk Inc. | Generating Reports from Unstructured Data |
US9471651B2 (en) * | 2012-10-08 | 2016-10-18 | Hewlett Packard Enterprise Development Lp | Adjustment of map reduce execution |
CN103714096B (en) | 2012-10-09 | 2018-02-13 | 阿里巴巴集团控股有限公司 | Inverted index system constructing, data processing method and device based on Lucene |
US20140114993A1 (en) * | 2012-10-22 | 2014-04-24 | Yahoo! Inc. | Method and system for maintaining data in a data storage system |
WO2014117295A1 (en) * | 2013-01-31 | 2014-08-07 | Hewlett-Packard Development Company, L.P. | Performing an index operation in a mapreduce environment |
US9305067B2 (en) | 2013-07-19 | 2016-04-05 | International Business Machines Corporation | Creation of change-based data integration jobs |
US9734192B2 (en) * | 2013-09-20 | 2017-08-15 | Oracle International Corporation | Producing sentiment-aware results from a search query |
CN103593401B (en) * | 2013-10-15 | 2016-08-10 | 北京航空航天大学 | Code conversion method and device |
US10437819B2 (en) | 2014-11-14 | 2019-10-08 | Ab Initio Technology Llc | Processing queries containing a union-type operation |
US10417281B2 (en) * | 2015-02-18 | 2019-09-17 | Ab Initio Technology Llc | Querying a data source on a network |
US10229150B2 (en) | 2015-04-23 | 2019-03-12 | Splunk Inc. | Systems and methods for concurrent summarization of indexed data |
WO2016183546A1 (en) | 2015-05-14 | 2016-11-17 | Walleye Software, LLC | Computer data system current row position query language construct |
CN107784030B (en) | 2016-08-31 | 2020-04-28 | 华为技术有限公司 | Method and device for processing connection query |
CN106445645B (en) * | 2016-09-06 | 2019-11-26 | 北京百度网讯科技有限公司 | Method and apparatus for executing distributed computing task |
US10474674B2 (en) | 2017-01-31 | 2019-11-12 | Splunk Inc. | Using an inverted index in a pipelined search query to determine a set of event data that is further limited by filtering and/or processing of subsequent query pipestages |
US11379530B2 (en) | 2017-01-31 | 2022-07-05 | Splunk Inc. | Leveraging references values in inverted indexes to retrieve associated event records comprising raw machine data |
US10866943B1 (en) | 2017-08-24 | 2020-12-15 | Deephaven Data Labs Llc | Keyed row selection |
US11200238B2 (en) * | 2019-01-28 | 2021-12-14 | Roblox Corporation | Computing cross products using map reduce |
CN111125264B (en) * | 2019-12-12 | 2021-05-28 | 跬云(上海)信息科技有限公司 | Extra-large set analysis method and device based on extended OLAP model |
US12001416B1 (en) * | 2021-04-20 | 2024-06-04 | The Travelers Indemnity Company | Systems and methods for generic data parsing applications |
CN113190528B (en) * | 2021-04-21 | 2022-12-06 | 中国海洋大学 | Parallel distributed big data architecture construction method and system |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050004904A1 (en) * | 2003-05-07 | 2005-01-06 | Oracle International Corporation | Exposing multidimensional calculations through structured query language |
US20050033741A1 (en) * | 2003-05-07 | 2005-02-10 | Oracle International Corporation | Efficient processing of relational joins of multidimensional data |
US6968335B2 (en) | 2002-11-14 | 2005-11-22 | Sesint, Inc. | Method and system for parallel processing of database queries |
US7185003B2 (en) | 2002-11-14 | 2007-02-27 | Seisint, Inc. | Query scheduling in a parallel-processing database system |
US20070174278A1 (en) | 2006-01-13 | 2007-07-26 | Bhashyam Ramesh | Method and system for performing logical partial declustering |
US20080086442A1 (en) | 2006-10-05 | 2008-04-10 | Yahoo! Inc. | Mapreduce for distributed database processing |
US20080120314A1 (en) | 2006-11-16 | 2008-05-22 | Yahoo! Inc. | Map-reduce with merge to process multiple relational datasets |
US20080127146A1 (en) * | 2006-09-06 | 2008-05-29 | Shih-Wei Liao | System and method for generating object code for map-reduce idioms in multiprocessor systems |
-
2008
- 2008-10-10 US US12/249,780 patent/US7917463B2/en active Active
-
2009
- 2009-02-10 WO PCT/US2009/033623 patent/WO2010042238A1/en active Application Filing
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6968335B2 (en) | 2002-11-14 | 2005-11-22 | Sesint, Inc. | Method and system for parallel processing of database queries |
US7185003B2 (en) | 2002-11-14 | 2007-02-27 | Seisint, Inc. | Query scheduling in a parallel-processing database system |
US20050004904A1 (en) * | 2003-05-07 | 2005-01-06 | Oracle International Corporation | Exposing multidimensional calculations through structured query language |
US20050033741A1 (en) * | 2003-05-07 | 2005-02-10 | Oracle International Corporation | Efficient processing of relational joins of multidimensional data |
US20070174278A1 (en) | 2006-01-13 | 2007-07-26 | Bhashyam Ramesh | Method and system for performing logical partial declustering |
US20080127146A1 (en) * | 2006-09-06 | 2008-05-29 | Shih-Wei Liao | System and method for generating object code for map-reduce idioms in multiprocessor systems |
US20080086442A1 (en) | 2006-10-05 | 2008-04-10 | Yahoo! Inc. | Mapreduce for distributed database processing |
US20080120314A1 (en) | 2006-11-16 | 2008-05-22 | Yahoo! Inc. | Map-reduce with merge to process multiple relational datasets |
Cited By (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090063441A1 (en) * | 2003-05-27 | 2009-03-05 | Styles Michael E | System and method of query transformation |
US8108415B2 (en) * | 2003-05-27 | 2012-01-31 | International Business Machines Corporation | Query transformation |
US20050038782A1 (en) * | 2003-05-27 | 2005-02-17 | Styles Michael E. | System and method of summary filter transformation |
US8676821B2 (en) | 2003-05-27 | 2014-03-18 | Sap Ag | Summary filter transformation |
US20070150436A1 (en) * | 2005-12-22 | 2007-06-28 | Oracle International Corporation | Query generator |
US8166020B2 (en) * | 2005-12-22 | 2012-04-24 | Oracle International Corporation | Query generator |
US20100175049A1 (en) * | 2009-01-07 | 2010-07-08 | Microsoft Corporation | Scope: a structured computations optimized for parallel execution script language |
US9514188B2 (en) | 2009-04-02 | 2016-12-06 | Pivotal Software, Inc. | Integrating map-reduce into a distributed relational database |
US20100257198A1 (en) * | 2009-04-02 | 2010-10-07 | Greeenplum, Inc. | Apparatus and method for integrating map-reduce into a distributed relational database |
US8713038B2 (en) * | 2009-04-02 | 2014-04-29 | Pivotal Software, Inc. | Integrating map-reduce into a distributed relational database |
US20100313205A1 (en) * | 2009-06-09 | 2010-12-09 | Yahoo! Inc., A Delaware Corporation | System and method for offline data generation for online system analysis |
US8321873B2 (en) * | 2009-06-09 | 2012-11-27 | Yahoo! Inc. | System and method for offline data generation for online system analysis |
US10795705B2 (en) * | 2010-05-04 | 2020-10-06 | Google Llc | Parallel processing of data |
US11392398B2 (en) | 2010-05-04 | 2022-07-19 | Google Llc | Parallel processing of data |
US12026532B2 (en) | 2010-05-04 | 2024-07-02 | Google Llc | Parallel processing of data |
US11755351B2 (en) | 2010-05-04 | 2023-09-12 | Google Llc | Parallel processing of data |
US20190317782A1 (en) * | 2010-05-04 | 2019-10-17 | Google Llc | Parallel Processing of Data |
US9317542B2 (en) | 2011-10-04 | 2016-04-19 | International Business Machines Corporation | Declarative specification of data integration workflows for execution on parallel processing platforms |
US9361323B2 (en) | 2011-10-04 | 2016-06-07 | International Business Machines Corporation | Declarative specification of data integration workflows for execution on parallel processing platforms |
US9582528B2 (en) | 2011-11-10 | 2017-02-28 | Treasure Data, Inc. | System and method for operating a big-data platform |
WO2013070873A1 (en) * | 2011-11-10 | 2013-05-16 | Treasure Data, Inc. | System and method for operating a big-data platform |
US11455287B1 (en) * | 2012-08-01 | 2022-09-27 | Tibco Software Inc. | Systems and methods for analysis of data at disparate data sources |
US9418085B1 (en) | 2013-03-13 | 2016-08-16 | Amazon Technologies, Inc. | Automatic table schema generation |
US10289396B2 (en) | 2013-12-06 | 2019-05-14 | Ab Initio Technology Llc | Source code translation |
US11106440B2 (en) | 2013-12-06 | 2021-08-31 | Ab Initio Technology Llc | Source code translation |
US10282181B2 (en) | 2013-12-06 | 2019-05-07 | Ab Initio Technology Llc | Source code translation |
US9639407B1 (en) * | 2014-12-09 | 2017-05-02 | Parallel Machines Ltd. | Systems and methods for efficiently implementing functional commands in a data processing system |
US11093223B2 (en) | 2019-07-18 | 2021-08-17 | Ab Initio Technology Llc | Automatically converting a program written in a procedural programming language into a dataflow graph and related systems and methods |
Also Published As
Publication number | Publication date |
---|---|
US20090055370A1 (en) | 2009-02-26 |
WO2010042238A1 (en) | 2010-04-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7917463B2 (en) | System and method for data warehousing and analytics on a distributed file system | |
CN111971666B (en) | Dimension context propagation technique for optimizing SQL query plans | |
JP6617117B2 (en) | Scalable analysis platform for semi-structured data | |
US20200379997A1 (en) | Materialized views based on access rights | |
US20190138523A1 (en) | Processing database queries using format conversion | |
US8655861B2 (en) | Query metadata engine | |
US8521867B2 (en) | Support for incrementally processing user defined aggregations in a data stream management system | |
US20190026336A1 (en) | Retrieving data from a data storage system | |
US9298829B2 (en) | Performing a function on rows of data determined from transitive relationships between columns | |
US20140351233A1 (en) | System and method for continuous analytics run against a combination of static and real-time data | |
US7577637B2 (en) | Communication optimization for parallel execution of user-defined table functions | |
US20200379994A1 (en) | Sharing Materialized Views In Multiple Tenant Database Systems | |
CN111966692A (en) | Data processing method, medium, device and computing equipment for data warehouse | |
CN104767813A (en) | Public bank big data service platform based on openstack | |
CN110019314B (en) | Dynamic data encapsulation method, client and server based on data item analysis | |
Rodrigues et al. | Big data processing tools: An experimental performance evaluation | |
US11416477B2 (en) | Systems and methods for database analysis | |
US11586620B2 (en) | Object scriptability | |
Salem et al. | Active XML-based Web data integration | |
EP4150484A1 (en) | Efficient indexing for querying arrays in databases | |
CN115237937A (en) | Distributed collaborative query processing system based on interplanetary file system | |
US10248702B2 (en) | Integration management for structured and unstructured data | |
Leida et al. | Semantics-aware data integration for heterogeneous data sources | |
US12093289B2 (en) | Relationship-based display of computer-implemented documents | |
US20220318314A1 (en) | System and method of performing a query processing in a database system using distributed in-memory technique |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: BUSINESS.COM, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DAGUM, PAUL;SINGH, TARANDEEP;DAGUM, LEONARDO;REEL/FRAME:021677/0367 Effective date: 20081010 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: DEX ONE SERVICE, INC., NORTH CAROLINA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:DEX ONE DIGITAL, INC.;REEL/FRAME:030300/0370 Effective date: 20130426 Owner name: DEX ONE DIGITAL, INC., NORTH CAROLINA Free format text: CHANGE OF NAME;ASSIGNOR:BUSINESS.COM, INC.;REEL/FRAME:030300/0147 Effective date: 20110919 |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: WILMINGTON TRUST, NATIONAL ASSOCIATION, MINNESOTA Free format text: SECURITY INTEREST;ASSIGNORS:DEX MEDIA HOLDINGS, INC.;DEX ONE SERVICE, INC.;SUPERMEDIA LLC;REEL/FRAME:039304/0666 Effective date: 20160729 |
|
AS | Assignment |
Owner name: WILMINGTON TRUST, NATIONAL ASSOCIATION, MINNESOTA Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE SIGNATURE PAGE OF THE SECURITY AGREEMENT PREVIOUSLY RECORDED ON REEL 039304 FRAME 0666. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY INTEREST;ASSIGNORS:DEX MEDIA HOLDINGS, INC.;DEX ONE SERVICE, INC.;SUPERMEDIA LLC;REEL/FRAME:039682/0579 Effective date: 20160729 |
|
AS | Assignment |
Owner name: WELLS FARGO BANK, NATIONAL ASSOCIATION, NEW YORK Free format text: SECURITY AGREEMENT;ASSIGNORS:DEX MEDIA HOLDINGS, INC.;SUPERMEDIA LLC;REEL/FRAME:040983/0707 Effective date: 20161215 |
|
AS | Assignment |
Owner name: DEX MEDIA, INC., TEXAS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:DEX ONE SERVICE, INC.;REEL/FRAME:043961/0874 Effective date: 20171025 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 8 |
|
AS | Assignment |
Owner name: THRYV, INC., TEXAS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:DEX MEDIA, INC.;REEL/FRAME:051885/0080 Effective date: 20200220 |
|
AS | Assignment |
Owner name: WELLS FARGO BANK, NATIONAL ASSOCIATION, AS ADMINISTRATIVE AGENT, COLORADO Free format text: SECURITY INTEREST;ASSIGNOR:THRYV, INC.;REEL/FRAME:055452/0258 Effective date: 20210301 |
|
AS | Assignment |
Owner name: THRYV HOLDINGS, INC. (FORMERLY KNOWN AS DEX MEDIA HOLDINGS, INC.), TEXAS Free format text: RELEASE OF SECURITY INTEREST IN INTELLECTUAL PROPERTY;ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION., AS ADMINISTRATIVE AGENT;REEL/FRAME:055472/0592 Effective date: 20210301 Owner name: THRYV, INC. (FORMERLY KNOWN AS DEX MEDIA, INC.), TEXAS Free format text: RELEASE OF SECURITY INTEREST IN INTELLECTUAL PROPERTY;ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION., AS ADMINISTRATIVE AGENT;REEL/FRAME:055472/0592 Effective date: 20210301 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
FEPP | Fee payment procedure |
Free format text: 11.5 YR SURCHARGE- LATE PMT W/IN 6 MO, LARGE ENTITY (ORIGINAL EVENT CODE: M1556); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 12 |
|
AS | Assignment |
Owner name: CITIZENS BANK, N.A., MASSACHUSETTS Free format text: SECURITY INTEREST;ASSIGNOR:THRYV, INC.;REEL/FRAME:067287/0759 Effective date: 20240501 |
|
AS | Assignment |
Owner name: CITIZENS BANK, N.A., MASSACHUSETTS Free format text: SECURITY INTEREST;ASSIGNOR:THRYV, INC.;REEL/FRAME:067310/0627 Effective date: 20240501 |
|
AS | Assignment |
Owner name: THRYV, INC., TEXAS Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:WELLS FARGO BANK, NATIONAL ASSOCIATION;REEL/FRAME:067341/0434 Effective date: 20240501 |