Vectorh: Taking SQL-On-Hadoop to the Next Level

Total Page:16

File Type:pdf, Size:1020Kb

Vectorh: Taking SQL-On-Hadoop to the Next Level VectorH: Taking SQL-on-Hadoop to the Next Level Andrei Costeaz Adrian Ionescuz Bogdan Raducanu˘ z Michał Switakowski´ z Cristian Bârca˘ z Juliusz Sompolskiz Alicja Łuszczakz Michał Szafranski´ z Giel de Nijsz Peter Bonczx Actian Corp.z CWIx ABSTRACT SQL-on-Hadoop=MPP DBMS? A SQL-on-Hadoop sys- Actian Vector in Hadoop (VectorH for short) is a new SQL- tem shares certain characteristics with an analytical parallel on-Hadoop system built on top of the fast Vectorwise an- DBMS, such as Teradata. First of all, these so-called MPP alytical database system. VectorH achieves fault tolerance systems are used in analytical workloads, which consist of and storage scalability by relying on HDFS, and extends the relatively few very heavy queries { compared to transac- state-of-the-art in SQL-on-Hadoop systems by instrument- tional workloads { that perform heavy scans, joins, aggrega- ing the HDFS replication policy to optimize read locality. tions and analytical SQL, such as SQL'2003 window func- VectorH integrates with YARN for workload management, tions based on PARTITION BY, ROLL UP and GROUP- achieving a high degree of elasticity. Even though HDFS is ING SETS. That said, these workloads are by no means an append-only filesystem, and VectorH supports (update- read-only, and systems must also sustain a continuous stream averse) ordered tables, trickle updates are possible thanks to of voluminous updates under limited concurrency. Positional Delta Trees (PDTs), a differential update struc- In the past decade, analytical database systems have seen ture that can be queried efficiently. We describe the changes the rise of (i) columnar stores { which reduce the amount of made to single-server Vectorwise to turn it into a Hadoop- IO and memory bandwidth needed in query processing fur- based MPP system, encompassing workload management, ther boosted by (ii) integrated data compression and (iii) fa- parallel query optimization and execution, HDFS storage, cilities that allow data skipping in many queries, e.g. through transaction processing and Spark integration. We evaluate lightweight index structures like MinMax indexes that ex- VectorH against HAWQ, Impala, SparkSQL and Hive, show- ploit natural orders and correlations in the data. Such mod- ing orders of magnitude better performance. ern analytical database systems typically (iv) use a query en- gine that is (re)designed to exploit modern hardware strengths. Two approaches for this are popular. Vectorwise [27] devel- 1. INTRODUCTION oped the first fully vectorized query engine where all opera- Hadoop, originally an open-source copy of MapReduce, tions on data are performed on vectors of values, rather than has become the standard software layer for Big Data clus- tuple-at-a-time, reducing query interpretation overhead, in- ters. Though MapReduce is losing market share as the pro- creasing data and code CPU cache locality and allowing to gramming framework of choice to an ever-expanding range of use SIMD instructions. The competing approach is to use competing options and meta-frameworks, most prominently Just-In-Time (JIT) compilation, such that a SQL query is Spark [26], Hadoop has established itself as the software translated into assembly instructions { see Impala [24]. base for a variety of technologies, thanks to its evolution A commonality between SQL-on-Hadoop and MPP sys- which decoupled the YARN resource manager from MapRe- tems is that both run on a cluster of nodes; both systems duce and the wide adoption of its distributed file system must distribute data in some way over this cluster and when HDFS, which has become the de-facto standard for cheap a single query is run it must ideally parallelize over all nodes scalable storage for on-premise clusters. SQL-on-Hadoop { and all their cores { in this cluster. While this shared systems allow to connect existing SQL-based business ap- goal is obvious, it requires a lot of technical excellence in plications with the results of \big data" pipelines, adding to data placement, query optimization and execution to achieve their worth, further accelerating the adoption of Hadoop in near-linear parallel scalability on complex SQL queries. Both commercial settings. This paper describes VectorH, a new kinds of system, finally, must be prepared for nodes or links SQL-on-Hadoop system with advanced query execution, up- between them to go down (un)expectedly, and thus replicate datability, YARN, HDFS and Spark integration. data and take measures to achieve fault tolerance. Permission to make digital or hard copies of all or part of this work for personal or SQL-on-Hadoop6=MPP DBMS. There are also signif- classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation icant differences between SQL-on-Hadoop and MPP sys- on the first page. Copyrights for components of this work owned by others than the tems. MPP systems typically run on a dedicated cluster, and author(s) must be honored. Abstracting with credit is permitted. To copy otherwise, or sometimes even on specific hardware (database machines), republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected]. whereas SQL-on-Hadoop systems share a Hadoop cluster SIGMOD ’16, June 26–July 1, 2016, San Francisco, California, USA. with other workloads. The task of dividing the hardware re- sources between concurrent parallel queries is already hard © 2016 Copyright held by the owner/author(s). Publication rights licensed to ACM. ISBN 978-1-4503-1247-9/12/05. $15.00 in MPP, but when other Hadoop jobs also take cores, mem- DOI: http://dx.doi.org/10.1145/2882903.2903742 ory, network and disk bandwidth, this becomes even harder. In order to counter this problem, all members of the Hadoop 2. FROM VECTORWISE TO VECTORH ecosystem should coordinate their resource usage through a In this section we first summarize the most relevant fea- resource manager such as YARN. tures of the Vectorwise system, the performance-leading1 By basing data storage on HDFS, SQL-on-Hadoop sys- single-server Actian Vector product. Then, we provide a tems leverage scalability and fault-tolerance for a large part short overview of how this technology was used to architect from their Hadoop infrastructure; whereas MPP systems the new shared-nothing Actian VectorH SQL-on-Hadoop must introduce specific and proprietary mechanisms for fault product, which also serves as roadmap for the paper. tolerance (e.g. for adding and removing hardware, reacting gracefully to failures, monitoring status). MPP systems are Relevant Vectorwise Features. Vectorized processing typically more expensive, not only in upfront software and performs any operation on data at the granularity of vec- hardware cost, but also in terms of administration cost; the tors (mini-columns) of roughly 1000 elements. This dramat- required expertise is more rare than that for maintaining a ically reduces the overhead typically present in row-based Hadoop cluster, which has become a standard in this space. query engines that interpret query plans tuple-at-a-time [4]. In some analysis scenarios, raw data first needs to be Additionally, instruction cache locality increases as the in- processed with methods and algorithms that cannot be ex- terpreter stays longer in each function, and memory band- pressed in SQL, but better in a programming language. width consumption is reduced as all vectors reside in the MPP systems have introduced proprietary UDF (User De- CPU data cache. Vectorized execution exposes possibilities fined Function) interfaces with differing degrees of expres- to leverage features of modern CPUs like SIMD instructions sive power in an attempt to address this, whereas in SQL- in database workloads and increases analytical query perfor- on-Hadoop it is more natural to use parallel programming mance by an order of magnitude. The vectorized execution frameworks like Spark for such tasks. The advantage of this model has been adopted by analytical subsystems such as approach is that Spark is more powerful and flexible than IBM BLU [20] and SQLserver column indexes [17]; and it is any UDF API, and is open, so re-use in creating UDFs is also being deployed in new releases of Hive [13]. more likely. SQL-on-Hadoop systems thus must fit seam- Vectorwise introduced the compression schemes PFOR, lessly into \big data" pipelines, either through integrated PFOR-DELTA and PDICT, designed to achieve good com- APIs or through an ability to read and write large datasets pression ratios even with skewed frequency value distribu- in a number of standard formats (text, binary, ORC, Par- tions, as well as high decompression speed [28]. PDICT is quet) stored via HDFS on the cluster. dictionary compression, PFOR is zero prefix compression VectorH Features and Contributions. VectorH is a when representing values as the difference from a block- SQL-on-Hadoop system whose prime contribution is (i) to dependent base (the Frame Of Reference). PFOR-DELTA provide vastly superior query processing performance. This compresses deltas between subsequent tuples using PFOR, higher performance is based on a combination of a truly and has been adopted by the Lucene system to store its in- vectorized query engine, compressed columnar data formats verted text index. These schemes represent values as thin with better lightweight compression methods than those used fixed-bitwidth codes packed together, but store infrequent in common Hadoop formats, and better data skipping statis- values uncompressed as \exceptions" later in the block. The tics than these common formats. Its SQL technology is ma- letter P in these stands for \Patched", since decompression ture, which is especially visible in the query plan quality first inflates all values from the compressed codes; then in produced by its cost-based query optimizer, but is also ob- a second phase patches the values that were exceptions by served in its robust SQL support including analytical SQL, hopping over the decompressed codes starting from the first encryption, authentication, and user role management.
Recommended publications
  • Voodoo - a Vector Algebra for Portable Database Performance on Modern Hardware
    Voodoo - A Vector Algebra for Portable Database Performance on Modern Hardware Holger Pirk Oscar Moll Matei Zaharia Sam Madden MIT CSAIL MIT CSAIL MIT CSAIL MIT CSAIL [email protected] [email protected] [email protected] [email protected] ABSTRACT Single Thread Branch Multithread Branch GPU Branch In-memory databases require careful tuning and many engi- Single Thread No Branch Multithread No Branch GPU No Branch neering tricks to achieve good performance. Such database performance engineering is hard: a plethora of data and 10 hardware-dependent optimization techniques form a design space that is difficult to navigate for a skilled engineer { even more so for a query compiler. To facilitate performance- 1 oriented design exploration and query plan compilation, we present Voodoo, a declarative intermediate algebra that ab- stracts the detailed architectural properties of the hard- ware, such as multi- or many-core architectures, caches and Absolute time in s 0.1 SIMD registers, without losing the ability to generate highly tuned code. Because it consists of a collection of declarative, vector-oriented operations, Voodoo is easier to reason about 1 5 10 50 100 and tune than low-level C and related hardware-focused ex- Selectivity tensions (Intrinsics, OpenCL, CUDA, etc.). This enables Figure 1: Performance of branch-free selections based on our Voodoo compiler to produce (OpenCL) code that rivals cursor arithmetics [28] (a.k.a. predication) over a branching and even outperforms the fastest state-of-the-art in memory implementation (using if statements) databases for both GPUs and CPUs. In addition, Voodoo makes it possible to express techniques as diverse as cache- conscious processing, predication and vectorization (again PeR [18], Legobase [14] and TupleWare [9], have arisen.
    [Show full text]
  • A Survey on Parallel Database Systems from a Storage Perspective: Rows Versus Columns
    A Survey on Parallel Database Systems from a Storage Perspective: Rows versus Columns Carlos Ordonez1 ? and Ladjel Bellatreche2 1 University of Houston, USA 2 LIAS/ISAE-ENSMA, France Abstract. Big data requirements have revolutionized database technol- ogy, bringing many innovative and revamped DBMSs to process transac- tional (OLTP) or demanding query workloads (cubes, exploration, pre- processing). Parallel and main memory processing have become impor- tant features to exploit new hardware and cope with data volume. With such landscape in mind, we present a survey comparing modern row and columnar DBMSs, contrasting their ability to write data (storage mecha- nisms, transaction processing, batch loading, enforcing ACID) and their ability to read data (query processing, physical operators, sequential vs parallel). We provide a unifying view of alternative storage mecha- nisms, database algorithms and query optimizations used across diverse DBMSs. We contrast the architecture and processing of a parallel DBMS with an HPC system. We cover the full spectrum of subsystems going from storage to query processing. We consider parallel processing and the impact of much larger RAM, which brings back main-memory databases. We then discuss important parallel aspects including speedup, sequential bottlenecks, data redistribution, high speed networks, main memory pro- cessing with larger RAM and fault-tolerance at query processing time. We outline an agenda for future research. 1 Introduction Parallel processing is central in big data due to large data volume and the need to process data faster. Parallel DBMSs [15, 13] and the Hadoop eco-system [30] are currently two competing technologies to analyze big data, both based on au- tomatic data-based parallelism on a shared-nothing architecture.
    [Show full text]
  • VECTORWISE Simply FAST
    VECTORWISE Simply FAST A technical whitepaper TABLE OF CONTENTS: Introduction .................................................................................................................... 1 Uniquely fast – Exploiting the CPU ................................................................................ 2 Exploiting Single Instruction, Multiple Data (SIMD) .................................................. 2 Utilizing CPU cache as execution memory ............................................................... 3 Other CPU performance features ............................................................................. 3 Leveraging industry best practices ................................................................................ 4 Optimizing large data scans ...................................................................................... 4 Column-based storage .............................................................................................. 4 VectorWise’s hybrid column store ........................................................................ 5 Positional Delta Trees (PDTs) .............................................................................. 5 Data compression ..................................................................................................... 6 VectorWise’s innovative use of data compression ............................................... 7 Storage indexes ........................................................................................................ 7 Parallel
    [Show full text]
  • Micro Adaptivity in Vectorwise
    Micro Adaptivity in Vectorwise Bogdan Raducanuˇ Peter Boncz Actian CWI [email protected] [email protected] ∗ Marcin Zukowski˙ Snowflake Computing marcin.zukowski@snowflakecomputing.com ABSTRACT re-arrange the shape of a query plan in reaction to its execu- Performance of query processing functions in a DBMS can tion so far, thereby enabling the system to correct mistakes be affected by many factors, including the hardware plat- in the cost model, or to e.g. adapt to changing selectivities, form, data distributions, predicate parameters, compilation join hit ratios or tuple arrival rates. Micro Adaptivity, intro- method, algorithmic variations and the interactions between duced here, is an orthogonal approach, taking adaptivity to these. Given that there are often different function imple- the micro level by making the low-level functions of a query mentations possible, there is a latent performance diversity executor more performance-robust. which represents both a threat to performance robustness Micro Adaptivity was conceived inside the Vectorwise sys- if ignored (as is usual now) and an opportunity to increase tem, a high performance analytical RDBMS developed by the performance if one would be able to use the best per- Actian Corp. [18]. The raw execution power of Vectorwise forming implementation in each situation. Micro Adaptivity, stems from its vectorized query executor, in which each op- proposed here, is a framework that keeps many alternative erator performs actions on vectors-at-a-time, rather than a function implementations (“flavors”) in a system. It uses a single tuple-at-a-time; where each vector is an array of (e.g.
    [Show full text]
  • Dbmoto® for Vectorwise™
    ® ™ DBMoto for Vectorwise Real-time Data Replication and CDC for Analytic Database Systems DBMoto® for Vectorwise™ DBMoto® is the preferred solution for heterogeneous Data Replication, Change Data Capture Powerful, Flexible, Configurable and Data Transformation requirements in an enterprise environment. DBMoto supports Change Data Capture! Actian’s™ Vectorwise™ Analytic Database System through built-in integration capabilities that DBMoto® does not require any programming provide seamless data loading and data mirroring to Vectorwise targets. Whether you need to on the source or target database platforms deploy a new Vectorwise system, or upgrade from an incumbent system, DBMoto can help in order to deploy or run its powerful data make data migration an easy and understandable task. integration features. DBMoto is the solution of choice for fast, trouble-free, easy-to-maintain data integration DBMoto provides all functionality in easy projects. If you depend on data from multiple databases, you need a data integration solution GUI and wizard-based screens: no stored that supports major relational database systems, and that works out-of-the-box. Using an procedures to develop; and no proprietary ecient visual interface, intuitive wizards and easy-to-follow guides, DBMoto helps IT sta syntax to learn. implement the toughest replication requirements quickly and easily. DBMoto is mature and approved by enterprises ranging from midsized to Fortune 1000 businesses worldwide. Databases Supported as Sources: Achieving dependable data delivery in enterprise environments requires expertise in database • IBM DB2 for i, AS400 • MySQL servers. HiT Software has been delivering relational data access products since 1994, and • IBM DB2 for z/OS (OS/390) • Sybase ASE DBMoto incorporates proven integration technology to ensure high performance yet minimally • DB2 LUW • SQL Anywhere intrusive data synchronization, using Change Data Capture for maximum eciency.
    [Show full text]
  • Monetdb: Open-Source Columnar Database Technology Beyond Textbooks
    MonetDB: Open-source Columnar Database Technology Beyond Textbooks http://www.monetdb.org/ Stefan Manegold [email protected] http://homepages.cwi.nl/~manegold/ Why? Motivation (early 1990s) ● Relational DBMSs dominate since the late 1970's / early 1980's ● IBM DB2, MS SQL Server, Oracle, Ingres, ... ● Transactional workloads (OLTP, row-wise access) ● I/O based processing ● But: ● Workloads change (early 1990s) ● Hardware changes (late 1990s) ● Data “explodes” (early 2000s) Why? Workload changes: Transactions (OLTP) vs ... Why? Workload changes: ... vs OLAP, BI, Data Mining, ... Why? Databases hit The Memory Wall . Detailed and exhaustive analysis for different workloads using 4 RDBMSs by Ailamaki, DeWitt, Hill, Wood in VLDB 1999: “DBMSs On A Modern Processor: Where Does Time Go?” . CPU is 60%-90% idle, waiting for memory: . L1 data stalls . L1 instruction stalls . L2 data stalls . TLB stalls . Branch mispredictions . Resource stalls Why? Hardware Changes: The Memory Wall Trip to memory = 1000s of instructions! Why? Hardware Changes: Memory Hierarchies +Transition Lookaside Buffer (TLB) Cache for VM address translation only 64 entries! How? Solution “We can't solve problems by using the same kind of thinking we used when we created them.” What? MonetDB ● Database kernel developed at CWI since 1993 ● Research prototype turned into open-source product ● Pioneering columnar database architecture ● Complete Relational/SQL & XML/XQuery DBMS ● Focusing on in-memory processing ● Data is kept persistent on disk and can exceed memory limits ● Aiming at OLAP, BI, data mining & scientific workloads (“read-dominated”) ● Supporting ACID transactions (WAL, optimistic CC) ● Platform for database architecture research ● Used in academia (research & teaching) & commercial environments ● Back-end for various DB research projects: Multi-Media DB & IR (“Tijah”), XML/XQuery (“Pathfinder”), Data Mining (“Proximity”), Digital Forensics (“XIRAF”), GIS (“OSM”), ..
    [Show full text]
  • (Spring 2019) :: Query Execution & Processing
    ADVANCED DATABASE SYSTEMS Query Execution & Processing @Andy_Pavlo // 15-721 // Spring 2019 Lecture #15 CMU 15-721 (Spring 2019) 2 ARCHITECTURE OVERVIEW Networking Layer SQL Query SQL Parser Planner Binder Rewriter Optimizer / Cost Models Compiler Scheduling / Placement Concurrency Control We Are Here Execution Engine Operator Execution Indexes Storage Models Storage Manager Logging / Checkpoints CMU 15-721 (Spring 2019) 3 OPERATOR EXECUTION Query Plan Processing Application Logic Execution (UDFs) Parallel Join Algorithms Vectorized Operators Query Compilation CMU 15-721 (Spring 2019) 4 QUERY EXECUTION A query plan is comprised of operators. An operator instance is an invocation of an operator on some segment of data. A task is the execution of a sequence of one or more operator instances. CMU 15-721 (Spring 2019) 5 EXECUTION OPTIMIZATION We are now going to start discussing ways to improve the DBMS's query execution performance for data sets that fit entirely in memory. There are other bottlenecks to target when we remove the disk. CMU 15-721 (Spring 2019) 6 OPTIMIZATION GOALS Approach #1: Reduce Instruction Count → Use fewer instructions to do the same amount of work. Approach #2: Reduce Cycles per Instruction → Execute more CPU instructions in fewer cycles. → This means reducing cache misses and stalls due to memory load/stores. Approach #3: Parallelize Execution → Use multiple threads to compute each query in parallel. CMU 15-721 (Spring 2019) 7 MonetDB/X100 Analysis Processing Models Parallel Execution CMU 15-721 (Spring 2019) 8 MONETDB/X100 Low-level analysis of execution bottlenecks for in- memory DBMSs on OLAP workloads. → Show how DBMS are designed incorrectly for modern CPU architectures.
    [Show full text]
  • Vectorwise: Beyond Column Stores
    Vectorwise: Beyond Column Stores Marcin Zukowski, Actian, Amsterdam, The Netherlands Peter Boncz, CWI, Amsterdam, The Netherlands Abstract This paper tells the story of Vectorwise, a high-performance analytical database system, from multiple perspectives: its history from academic project to commercial product, the evolution of its technical architecture, customer reactions to the product and its future research and development roadmap. One take-away from this story is that the novelty in Vectorwise is much more than just column-storage: it boasts many query processing innovations in its vectorized execution model, and an adaptive mixed row/column data storage model with indexing support tailored to analytical workloads. Another one is that there is a long road from research prototype to commercial product, though database research continues to achieve a strong innovative influence on product development. 1 Introduction The history of Vectorwise goes back to 2003 when a group of researchers from CWI in Amsterdam, known for the MonetDB project [5], invented a new query processing model. This vectorized query processing approach became the foundation of the X100 project [6]. In the following years, the project served as a platform for further improvements in query processing [23, 26] and storage [24, 25]. Initial results of the project showed impressive performance improvements both in decision support workloads [6] as well as in other application areas like information retrieval [7]. Since the commercial potential of the X100 technology was apparent, CWI spun-out this project and founded Vectorwise BV as a company in 2008. Vectorwise BV decided to combine the X100 processing and storage components with the mature higher-layer database components and APIs of the Ingres DBMS; a product of Actian Corp.
    [Show full text]
  • Exploring Query Execution Strategies for JIT, Vectorization and SIMD
    Exploring Query Execution Strategies for JIT, Vectorization and SIMD Tim Gubner Peter Boncz CWI CWI [email protected] [email protected] ABSTRACT at-a-time execution of analytical queries is typically more This paper partially explores the design space for efficient than 90% of CPU work [4], hence block-at-a-time often de- query processors on future hardware that is rich in SIMD livers an order of magnitude better performance. capabilities. It departs from two well-known approaches: An alternative way to avoid interpretation overhead is (1) interpreted block-at-a-time execution (a.k.a. \vector- Just-In-Time (JIT) compilation of database query pipelines ization") and (2) \data-centric" JIT compilation, as in the into low-level instructions (e.g. LLVM intermediate code). HyPer system. We argue that in between these two de- This approach was proposed and demonstrated in HyPer [9], sign points in terms of granularity of execution and unit of and has also been adopted in Spark SQL for data science compilation, there is a whole design space to be explored, workloads. The data-centric compilation that HyPer pro- in particular when considering exploiting SIMD. We focus poses, however, leads to tight tuple-at-a-time loops, which on TPC-H Q1, providing implementation alternatives (“fla- means that so far these architectures do not exploit SIMD, vors") and benchmarking these on various architectures. In since for that typically multiple tuples need to be executed doing so, we explain in detail considerations regarding oper- on at the same time. JIT compilation is not only beneficial ating on SQL data in compact types, and the system features for analytical queries but also transactional queries, and thus that could help using as compact data as possible.
    [Show full text]
  • Vectorwise Developer Guide Technical White Paper
    Vectorwise Developer Guide Technical white paper 1 Table of Contents INTRODUCTION 2 SYSTEM SIZING 3 Determine the core count ................................................. 3 How much memory do I need? ......................................... 5 Sizing disk storage ............................................................ 7 DATABASE CONFIGURATION 11 Access to data ................................................................ 11 Storage allocation ........................................................... 13 SCHEMA DESIGN 14 Indexing .......................................................................... 14 Constraints ...................................................................... 15 DATA LOADING 16 Initial data load ................................................................ 16 Incremental data load ..................................................... 19 HIGH AVAILABILITY 23 Hardware protection ....................................................... 23 Backup and restore ......................................................... 23 Standby configuration ..................................................... 26 MONITORING VECTORWISE 27 Actian Monitor ................................................................. 27 vwinfo utility .................................................................... 27 1 INTRODUCTION Welcome to the Vectorwise 2.5 Developer Guide. Vectorwise is a relational database that transparently utilizes performance features in CPUs to perform extremely fast reporting and data analysis to
    [Show full text]
  • Making BI Easier an Introduction to Vectorwise
    Taking Action on Big Data Making BI Easier An Introduction to Vectorwise [email protected] Actian Overview Taking Action on Big Data Ingres Vectorwise Action Apps. Cloud Action Platform •World class mission •World’s fastest Big Data •Taking BI forward, turning critical RDBMS Analytics engine Insight into Action •CREDIBILITY, RELIABILITY, •PROVEN INNOVATION •LEADERSHIP GLOBAL Privately owned, profitable, growing 30 year history of Database Software, Services and Solutions Actian technology used by over 10,000 customers worldwide Global 24 x 7 Support Confidential © 2011 Actian Corporation 2 Biggest Issues in BI Today Ease of Use Performance • 2011 Gartner Magic Quadrant • BI Survey 9 (2010): Why BI Projects Fail? • Ease of use’ is now the No. 1 reason why • 1. Query Performance Too Slow organizations select a BI platform — • 2010 TDWI Best Practices Report surpassing ‘functionality’, which has • “45% Poor Query Response the top traditionally been the No. 1 reason. problem that will eventually drive users • BeyeNETWORK to replace their current data warehouse • 79% rated ease-of-use as either ‘very platform.” important’ or ‘essential’ • 2010 Gartner Magic Quadrant Data • Only 23% said organization’s BI tool Warehousing easy to learn and use • 70% of data warehouses experience performance constrained issues of various types Confidential © 2011 Actian Corporation 3 Making BI Faster and Easier Business Intelligence Analytical Database The leading BI platform World’s fastest database for ease of use for BI and Reporting Confidential ©
    [Show full text]
  • Data Storage Structures
    CHAPTER 13 Data Storage Structures In Chapter 12 we studied the characteristics of physical storage media, focusing on magnetic disks and SSDs, and saw how to build fast and reliable storage systems using multiple disks in a RAID structure. In this chapter, we focus on the organization of data stored on the underlying storage media, and how data are accessed. Bibliographical Notes [Hennessy et al. (2017)] is a popular textbook on computer architecture, which in- cludes coverage of hardware aspects of translation look-aside buffers, caches, and memory-management units. The storage structure of specific database systems, such as IBM DB2, Oracle, Mi- crosoft SQL Server, and PostgreSQL are documented in their respective system man- uals, which are available online. Algorithms for buffer management in database systems, along with a performance evaluation, were presented by [Chou and Dewitt (1985)]. Buffer management in op- erating systems is discussed in most operating-system texts, including in [Silberschatz et al. (2018)]. [Abadi et al. (2008)] presents a comparison of column-oriented and row-oriented storage, including issues related to query processing and optimization. Sybase IQ, developed in the mid 1990s, was the first commercially successful column-oriented database, designed for analytics. MonetDB and C-Store were column- oriented databases developed as academic research projects. The Vertica column- oriented database is a commercial database that grew out of C-Store, while VectorWise is a commercial database that grew out of MonetDB. As its name suggests, VectorWise supports vector processing of data, and as a result supports very high processing rates for many analytical queries.
    [Show full text]