Migrating to Virtual Data Marts Using Data Virtualization Simplifying Business Intelligence Systems

Total Page:16

File Type:pdf, Size:1020Kb

Migrating to Virtual Data Marts Using Data Virtualization Simplifying Business Intelligence Systems Migrating to Virtual Data Marts using Data Virtualization Simplifying Business Intelligence Systems A Technical Whitepaper Rick F. van der Lans Independent Business Intelligence Analyst R20/Consultancy January 2015 Sponsored by Copyright © 2015 R20/Consultancy. All rights reserved. Cisco and the Cisco logo are trademarks or registered trademarks of Cisco and/or its affiliates in the U.S. or there countries. To view a list of Cisco trademarks, go to this URL: www.cisco.com/go/trademarks. Trademarks of companies referenced in this document are the sole property of their respective owners. Table of Contents 1 Introduction 1 2 Data Marts 1 3 The Costs of Data Marts 3 4 The Alternative: Virtual Data Marts using Data Virtualization 5 5 Developing Virtual Data Marts 6 Step 1: Recreating Physical Data Marts as Virtual Data Marts 6 Step 2: Improving Query Performance on Virtual Data Marts 12 Step 3: Identifying Common Specifications Among Virtual Data Marts 14 Step 4: Redirecting Reports to Access Virtual Data Marts 16 Step 5: Extracting Definitions from the Reporting Tools 16 Step 6: Defining Security Rules 16 Step 7: Adding External Data to Virtual Data Marts 17 6 Getting Started 17 About the Author Rick F. van der Lans 19 About Cisco Systems, Inc. 19 Copyright © 2015 R20/Consultancy, all rights reserved. Migrating to Virtual Data Marts using Data Virtualization 1 1 Introduction Almost every BI system is made up of many data marts. These data marts are commonly developed to improve query performance, to deliver to users the data with the right data structure and the right aggregation level, to minimize network delay for geographically dispersed users, to allow the use of specific database technologies, and to give the users more control over their data. Unfortunately, data marts are expensive because they require a lot of work to develop, operate, and maintain. They also complicate the architectures of BI systems. For example, changes made to the data warehouse can lead to a multitude of changes throughout all the data marts, and changes made to a report can involve complex modifications to the data marts and the corresponding ETL programs. In addition, they can degrade data quality and complicate data governance. But most importantly, data marts reduce the flexibility of a BI system. The main reason is that they are physical data marts, so they occupy disk storage, they must be loaded with new data periodically, they have to be managed, tuned, and optimized, and so on. Nowadays, organizations demand flexible BI systems. This does not mean that all the data marts should be dropped, because then all their benefits would disappear as well. A better solution is to replace physical data marts by virtual data marts. With virtual data marts data can still be delivered with the right structure, in the right form, and at the right data aggregation level. But they are not physical, so they do not occupy disk storage, they do not have to be loaded with new data periodically, they do not have to be managed, tuned, and optimized, and so on. Virtual data marts are much more flexible than physical data marts. Changing them is predominantly a change of specifications. Virtual data marts can be developed in various ways. This whitepaper describes in detail a step‐by‐step approach for migrating physical data marts to virtual data marts using Cisco Information Server (CIS). The approach is based on an evolutionary migration that does not impact the existing reporting workload. 2 Data Marts Data Marts – Most BI systems make use of data marts; see Figure 1. Some even comprises countless data marts. The data they contain is derived from the data warehouse. ETL programs are used to copy data from the data warehouse to the data marts periodically. Each data mart is developed for a specific group of users, all with comparable information and reporting needs. A data mart contains a subset of all the data from a data warehouse. Also, whereas a data warehouse contains the lowest level of data, a data mart usually contains a slightly aggregated version of all that data. Most reports run on one of those data marts instead of on the data warehouse. Copyright © 2015 R20/Consultancy, all rights reserved. Migrating to Virtual Data Marts using Data Virtualization 2 Figure 1 Traditionally, a BI system consists of many data marts. Why Are Data Marts Developed? – Usually, in a BI system the majority of all the reporting and analytics is processed on data marts. Common reasons for developing a data mart are: Query performance: The most dominant reason for organizations to develop data marts is query performance. Without data marts all the queries must be executed on the data warehouse. This query workload might be too intense for the database server managing the data warehouse, leading to long waiting times for the users. By implementing data marts, most of the queries are offloaded from the data warehouse to these data marts, and by distributing the query workload over multiple data marts, the performance of queries improves. Data structure: Particular reporting or analytical tools require data to have a certain structure. For example, a tool might demand that the tables are organized as a star schema. If the tables in the data warehouse are normalized, the tool won’t be able to access the data. In this case, a data mart is used to present the same data in the right structure. In such a system, ETL scripts are used to transform the normalized data to a star schema arrangement. Geographically dispersed users: If users are geographically dispersed, querying a central data store might lead to considerable network delay, which slows down the reports. In this situation, it’s better to move data physically closer to where the users are located, taking network traffic out of the equation. Storage technology: Data marts allow the use of different storage technologies for different reports and reporting tools. For example, the performance can be improved for certain reports by storing the data in a multi‐dimensional database server in which data is stored in a cube‐like form instead of in a SQL database server. Local control: By having a real copy of their data in a dedicated database, users have more control over that data. For example, it allows them to add private data or data from external sources to enrich their reporting capabilities. Copyright © 2015 R20/Consultancy, all rights reserved. Migrating to Virtual Data Marts using Data Virtualization 3 Technologies Used – As indicated, data marts can be developed with different data storage technologies. The most popular form is a SQL database. In this case, a separate set of tables is developed in a SQL database. Technically, this set of tables may be defined inside the database that contains the data warehouse, but quite often a separate database is developed. A second popular form is analytical cubes. Products such as Microsoft Analysis Service and KylinOLAP don’t store the data in tables, but in cubes in which the data is organized in dimensions and hierarchies. Data stored in cubes cannot be accessed using SQL, but through a dedicated language, such as MDX. The third option for storing the data of a data mart is by storing it in files, such as Microsoft Excel files, Microsoft Access files, or simple comma‐delimited files. Star Schema – The tables in a data mart developed with SQL technology are usually organized as a star schema1. In a star schema the tables are classified as dimension tables (or dimensional tables) and fact tables. Fact tables are the central tables in a star schema. A row in a fact table usually represents a business event. Examples of potential fact tables are money withdrawals from a bank account, bookings for a flight, and payments at a counter. Each row in a dimension table represents some business object, such as a customer, a product, or a department. Dimension tables don’t have relationships with each other, but only relationships with fact tables. Star schema owes its name to its graphical representation where the fact table forms the center and the dimension tables are drawn as rays originating from that center, together forming a star. The primary goal of arranging tables as a star schema is to limit the number of tables that have to be accessed and joined when a query is processed. The often cited advantage of avoiding table joins is improved query performance. Another advantage is that it becomes much easier to write queries and to present the end user with a set of options from which a tool can generate a query. The fact that duplicate data increases the amount of required storage is seen as less important. Also, the fact that duplicate data can lead to inconsistent data is not considered a major disadvantage as well, which makes sense in a data warehouse environment where all the inserts and updates are executed in a very controlled fashion. A data store can contain many fact tables and thus many star schemas. If fact tables share the same dimension tables, these dimension tables are called conformed dimension tables. This is only possible if those fact tables have been designed in such a way that they can use the same dimension tables. 3 The Costs of Data Marts The Price Tag of Data Marts – Quite often the decision to develop data marts is made lightheartedly. Query performance is commonly used as the all‐overriding argument. Unfortunately, data marts are more expensive than most organizations think. Already in 2008, Gartner2 indicated that the costs of derived data stores, such as data marts, are expensive components of an entire data warehouse architecture.
Recommended publications
  • The Roles of ETL, ESB, and Data Virtualization Technologies in Integration Landscape Chapter 1 Chapter 5 Data Integration Data Integration Strategies
    The Roles of ETL, ESB, and Data Virtualization Technologies in Integration Landscape Chapter 1 Chapter 5 Data Integration Data Integration Strategies 3-4 Compared 11 Chapter 2 Chapter 6 Extract, Transform, Load - Integrating Data Integration ETL Strategies 5 12 Chapter 3 Case Studies Enterprise Service Bus - ESB 7-8 13-15 Chapter 4 Data Virtualization - DV 9-10 The Roles of ETL, ESB, and Data Virtualization Technologies in Integration Landscape 2 Chapter 1 Data Integration Data Silo Syndrome The problem of data silos, which are data sources that are unable to easily share data from one to the other, has plagued the IT landscape for many years, and continues to do so today, despite the advents of broadband Internet, gigabit networking, and cloud-based storage. Data silos exists for a variety of reasons: • Old systems have trouble talking with modern systems. • On-premises systems have difficulty talking with cloud-based systems. • Some systems only work with specific applications. • Some systems are configured to be accessed by specific individuals or groups. • Companies acquire other companies, taking on differently-configured systems. The Roles of ETL, ESB, and Data Virtualization Technologies in Integration Landscape 3 Chapter 1 Bringing the Data Together The problem with data silos is that no one can run a query across them; they must be queried separately, and the separate results need to be added together manually, which is costly, time-consuming, and inefficient. To bring the data together, companies use one or more of the following data integration strategies: 1. Extract, Transform, and Load (ETL) Processes, which copy the data from the silos and move it to a central location, usually a data warehouse 2.
    [Show full text]
  • DATA VIRTUALIZATION: the Modern Data Integration Solution
    Whitepaper DATA VIRTUALIZATION: The Modern Data Integration Solution DATA VIRTUALIZATION LAYER Contents Abstract 3 Introduction 4 Traditional Integration Techniques 5 Data Virtualization 6 The Five Tiers of Data Virtualization Products 8 Summary: 10 Things to Know about Data Virtualization 9 Denodo Platform: The Modern Data Virtualization Platform 10 Abstract Organizations continue to struggle with integrating data quickly enough to support the needs of business stakeholders, who need integrated data faster and faster with each passing day. Traditional data integration technologies have not been able to solve the fundamental problem, as they deliver data in scheduled batches, and cannot support many of today’s rich and complex data types. Data virtualization is a modern data integration approach that is already meeting today’s data integration challenges, providing the foundation for data integration in the future. This paper covers the fundamental challenge, explains why traditional solutions fall short, and introduces data virtualization as the core solution. Introduction We have been living through an unprecedented explosion in the volume, variety, and velocity of incoming data. This is not new, but emerging technologies, such as the cloud and big data systems, which have brought large volumes of disparate data, have only compounded the problem. Different sources of data are still stored in functional silos, separate from other sources of data. Today, even data lakes contain multiple data silos. Business stakeholders need immediate information for real-time decisions, but this is challenging when the information they need is scattered across multiple sources. Similarly, initiatives like cloud first, app modernization, and big data analytics cannot move forward until data from key sources is brought together as a unified source.
    [Show full text]
  • Next-Generation Data Virtualization Fast and Direct Data Access, More Reuse, and Better Agility and Data Governance for BI, MDM, and SOA
    WHITE PAPER Next-Generation Data Virtualization Fast and Direct Data Access, More Reuse, and Better Agility and Data Governance for BI, MDM, and SOA Executive Summary It’s 9:00 a.m. and the CEO of a leading consumer electronics manufacturing company is meeting with the leadership team to discuss disturbing news. Significant errors in judgment resulted in the loss of millions of dollars in the last quarter. Overproduction substantially increased the costs of inventory. The sales team is not selling where market demands exist. Customer shipping errors are on the rise. With competitive threats at an all-time high, these are indeed disturbing developments for the company. All of these problems can be traced to one thing: the lack of a common view of all enterprise information assets across the company, on demand, when key decision makers need it. Some lines of business have stale or outdated data. Many define common entities, such as customer, product, sales, and inventory, differently. Others simply have incomplete and inaccurate data, or they can’t view the data in the proper context. A few years ago, a couple of business lines embarked on business intelligence (BI) projects to identify better cross-sell and up-sell opportunities. Their IT teams found that creating a common view of customer, product, sales, and inventory was no easy task. Data wasn’t just in the data warehouse—it was everywhere, and it was growing with each passing day. Various tools and integration approaches—such as hand coding, ETL, EAI, ESB, EII—were applied to access, integrate, and deliver all this data to different consuming applications.
    [Show full text]
  • Creating an Agile Data Integration Platform Using Data Virtualization a Technical Whitepaper
    Creating an Agile Data Integration Platform using Data Virtualization A Technical Whitepaper Rick F. van der Lans Independent Business Intelligence Analyst R20/Consultancy Sponsored by Copyright © 2014 R20/Consultancy. All rights reserved. Enterprise Enabler and Stone Bond are registered trademarks of Stone Bond Technologies L.P.. Trademarks of other companies referenced in this document are the sole property of their respective owners. Table of Contents 1 Management Summary 1 2 The Data Labyrinth 2 Data is the New Oil 2 Dispersion of Enterprise Data 2 The Diminishing Quality of Data 2 Improving the Quality of Data 3 3 The Data Integration Labyrinth 3 Increasing Need for Data Integration 3 Data Integration Silos 3 Disadvantages of a Data Integration Labyrinth 5 The Need for a Data Integration Platform 5 4 Data Virtualization as Data Integration Platform 6 The Need for a Service Hatch 6 Data Virtualization in a Nutshell 6 The Advantages of Data Virtualization 8 Data Virtualization as Basis for a Data Integration Platform 9 Data Virtualization Versus Enterprise Service Bus 9 5 Key Features of Data Virtualization 9 6 Stone Bond Technologies 11 History of Stone Bond Technologies 11 Products and Modules 11 7 Under the Hood of Enterprise Enabler Server 14 Transactional Support 14 The Three Model Approach 14 The Data Workflow Logic Process 15 8 Two Case Studies 17 DermSurgery Associates 17 Paradigm 17 About the Author Rick F. van der Lans 19 About Stone Bond Technologies L.P. 19 Copyright © 2014 R20/Consultancy, All Rights Reserved. Copyright © 2014 R20/Consultancy, All Rights Reserved. Creating an Agile Data Integration Platform using Data Virtualization 1 1 Management Summary Through the years, many organizations have built up massive amounts of enterprise data.
    [Show full text]
  • Data Virtualization – Flexible Technology for the Agile Enterprise
    INTELLIGENT BUSINESS STRATEGIES Data Virtualization – Flexible Technology for the Agile Enterprise By Mike Ferguson Intelligent Business Strategies February 2014 WHITE PAPER WHITE Prepared for: Data Virtualization – Flexible Technology for the Agile Enterprise Table of Contents What is Data Virtualization?.....................................................................................3 Why Data Virtualization? – What are the Business Drivers?...................................4 How Do Data Virtualization Products Work? ...........................................................6 Popular Data Virtualization Patterns........................................................................7 The Impact of Data Virtualization on the Enterprise ................................................9 The Impact on Data Warehouse Architecture ....................................9 Data Virtualization – Adding Agility to Ease Self-service BI .............10 Managing Performance While Accommodating Flexibility ...............11 Data Virtualization – Introducing Data Services in a SOA................12 Data Virtualization and Master Data Management...........................13 The Impact of Data Virtualization on Enterprise Data Governance..13 Requirements for Data Virtualization Technology .................................................15 Data Virtualization Product Example: SAS Federation Server ..............................17 Integration With SAS Data Management .........................................18 Data Virtualization and SAS Enterprise
    [Show full text]
  • Informatica's Intelligent Data Platform
    HRG Assessment: Informatica’s Intelligent Data Platform (IDP) Founded in 1993 Informatica went public April 29, 1999 on the NASDAQ Stock Exchange. August 6, 2015, in what Harvard Research Group sees as an excellent strategic move toward long term growth, Informatica and their investors took the company private and INFA ceased trading on the NASDAQ. Informatica's product portfolio is focused on, data integration, ETL, information lifecycle management, B2B data exchange, cloud data integration, complex event processing, data masking, data quality, data replication, data virtualization, master data management, and ultra messaging. Informatica’s customer base comprises more than 5,000 companies. The Informatica Intelligent Data Platform (IDP) is the centerpiece of the company’s reinvigorated strategic vision. IDP enables seamlessly integrated cross enterprise data management, bridging the gap between previous generation and current generation data management architectures. Focused around delivering the full potential of data fueled Cloud, Big Data, and IoT the Intelligent Data Platform offers a good way forward for customers looking toward the future. The Informatica Intelligent Data Platform represents a rebranding of the Informatica Platform which has been in use since PowerCenter, Informatica’s flagship product, was first released. IDP is represented in code however IDP is not a single entity. IDP is a combination of metadata (Live Data Map), task specific engines, and optimizers the combination of which defines IDP. Live Data Map is used extensively in Secure@Source and Intelligent Data Lake. IDP also supports streaming data-based solutions. Core products and services that leverage IDP capabilities include Secure@Source, Informatica Cloud, Informatica Big Data, Data Quality, Data Integration, Master Data Management (MDM), MDM 360, Informatica Data Lake, and the Informatica Enterprise Information Catalog (EIC).
    [Show full text]
  • Data Virtualization Usage Patterns for Business Intelligence/ Data Warehouse Architectures
    Whitepaper Data Virtualization Usage Patterns for Business Intelligence/ Data Warehouse Architectures WP-DVPatterns-01 Modern organisations are having to react ever more quickly to competitive threats and new potential market opportunities and more than ever before need data which is up to date, comprehensive and easy to access. Business Intelligence has long been a key method for making this available and in recent years the most common method of serving data to this environment has been through the replication of data into a Data Warehouse architecture. Now these BI/DW architectures have to evolve fast to meet the rapidly increasing demands of today´s businesses. From a business perspective traditional BI faces the following challenges: ▪ Lack of business agility: rigidity in the traditional BI/DW architecture prevents new or ad-hoc data requests from being fulfilled on time. ▪ Lost revenue opportunities: high latency in processing and delivering important data. ▪ High costs: tightly coupled systems make the modifications required to align to business needs expensive. ▪ Incomplete information for decision making: challenges in accessing disparate enterprise, web and unstructured data. ▪ Limited self-service opportunities: multiple layers of processing make it difficult for business users to operate without significant IT assistance. Today’s users demand reports with better business insights, more information sources, real-time data, more self-service and want these delivered more quickly, making it hard for the BI professionals to meet
    [Show full text]
  • Analysis of Data Virtualization & Enterprise Data Standardization in Business Intelligence
    Analysis of Data Virtualization & Enterprise Data Standardization in Business Intelligence Laljo John Pullokkaran Working Paper CISL# 2013-10 May 2013 Composite Information Systems Laboratory (CISL) Sloan School of Management, Room E62-422 Massachusetts Institute of Technology Cambridge, MA 02142 Analysis of Data Virtualization & Enterprise Data Standardization in Business Intelligence by Laljo John Pullokkaran B.Sc. Mathematics (1994) University of Calicut Masters in Computer Applications (1998) Bangalore University Submitted to the System Design and Management Program in Partial Fulfillment of the Requirements for the Degree of Master of Science in Engineering and Management at the Massachusetts Institute of Technology May 2013 © 2013 Laljo John Pullokkaran All rights reserved The author hereby grants to MIT permission to reproduce and to distribute publicly paper and electronic copies of this thesis document in whole or in part in any medium now known or hereafter created. Signature of Author Laljo John Pullokkaran System Design and Management Program May 2013 Certified by Stuart Madnick John Norris Maguire Professor of Information Technologies, Sloan School of Management and Professor of Engineering Systems, School of Engineering Massachusetts Institute of Technology Accepted by __________________________________________________________________________ Patrick Hale Director System Design & Management Program 1 Contents Abstract ........................................................................................................................................................................
    [Show full text]
  • Data Virtualization and Federation Metadata Comes of Age with Enterprise Enabler®
    WHITE PAPER Data Virtualization and Federation Metadata Comes of Age with Enterprise Enabler® Pamela Szabó Stone Bond Technologies Data Virtualization and Federation Copyright© 2014 Stone Bond Technologies, L.P. All rights reserved. The information contained in this document represents the current view of Stone Bond Technologies on the issue discussed as of the date of publication. This white paper is for information purposes only. Stone Bond Technologies may have patents, patent applications, trademark, copyright or other intellectual property rights covering the subject matter of this document. Except as expressly provided in any written license agreement from Stone Bond Technologies, the furnishing of this document does not give you any license to these patents, trademarks, copyrights or intellectual property. Stone Bond Technologies, L.P. 1020 Main Street Suite 1550 Houston, TX 77002 713-622-8798 Stone Bond Technologies Page 1 Data Virtualization and Federation Background The time has come for data virtualization and federation to step up to the plate. There have been waves of hype around the subject for many years, and although most approaches have had solid theoretical foundations, they have simply been too complex to implement and maintain in an ever-changing environment. Today’s demand and expectation by business end users for information has come in part from the overwhelming surge of social media and information access. SaaS applications, portals, and ubiquitous tools like SharePoint can be configured by non-programmers who need to access information and data to address their own needs. ISVs are producing best-of-breed line of business (LOB) applications at an alarming speed, as business software players strive to mimic consumer technology trends.
    [Show full text]
  • Whitepaper Title
    Cloud Native Data Virtualization on AWS Data Virtualization Guide September 2020 Notices Customers are responsible for making their own independent assessment of the information in this document. This document: (a) is for informational purposes only, (b) represents current AWS product offerings and practices, which are subject to change without notice, and (c) does not create any commitments or assurances from AWS and its affiliates, suppliers or licensors. AWS products or services are provided “as is” without warranties, representations, or conditions of any kind, whether express or implied. The responsibilities and liabilities of AWS to its customers are controlled by AWS agreements, and this document is not part of, nor does it modify, any agreement between AWS and its customers. © 2020 Amazon Web Services, Inc. or its affiliates. All rights reserved. Contents Introduction .......................................................................................................................... 1 Data Integration Challenges ................................................................................................ 3 Business Case ..................................................................................................................... 4 Data Virtualization Architecture ........................................................................................... 5 Custom Data Virtualization Solutions ................................................................................. 7 Commercial Data Virtualization Solutions
    [Show full text]
  • Modernizing the Data Warehouse
    Modernizing the Data Warehouse A Technical Whitepaper Norman F. Walters Freedom Consulting Group, Inc. August 2018 Copyright 2018 Freedom Consulting Group, Inc. All rights reserved. All other company and product names referenced in this document may be trademarks or registered trademarks of their respective owners. Copyright 2018 Freedom Consulting Group, Inc., all rights reserved i Table of Contents Table of Contents ...................................................................................................................... i Introduction .............................................................................................................................. 1 The EDW’s Role in Data Integration ...................................................................................... 1 Query Performance and Data Security in the EDW............................................................... 2 BI Challenges ........................................................................................................................... 4 Modernizing the EDW ............................................................................................................. 4 Modern Tools for a Modern Data Warehouse ......................................................................... 7 Copyright 2018 Freedom Consulting Group, Inc., all rights reserved Modernizing the Data Warehouse 1 Introduction With the advent of Big Data, cloud architectures, micro services and No SQL databases many organizations are asking themselves if they
    [Show full text]
  • Data Virtualization for Dummies®, Denodo Special Edition
    These materials are © 2019 John Wiley & Sons, Ltd. Any dissemination, distribution, or unauthorized use is strictly prohibited. Data Virtualization Denodo Special Edition by Lawrence C. Miller These materials are © 2019 John Wiley & Sons, Ltd. Any dissemination, distribution, or unauthorized use is strictly prohibited. Data Virtualization For Dummies®, Denodo Special Edition Published by: John Wiley & Sons, Ltd., The Atrium, Southern Gate Chichester, West Sussex, www.wiley.com © 2019 by John Wiley & Sons, Ltd., Chichester, West Sussex Registered Office John Wiley & Sons, Ltd., The Atrium, Southern Gate, Chichester, West Sussex, PO19 8SQ, United Kingdom All rights reserved. No part of this publication may be reproduced, stored in a retrieval system or transmitted in any form or by any means, electronic, mechanical, photocopying, recording, scanning or otherwise, except as permitted by the UK Copyright, Designs and Patents Act 1988, without the prior written permission of the Publisher. For information about how to apply for permission to reuse the copyright material in this book, please see our website http://www.wiley.com/go/permissions. Trademarks: Wiley, For Dummies, the Dummies Man logo, The Dummies Way, Dummies.com, Making Everything Easier, and related trade dress are trademarks or registered trademarks of John Wiley & Sons, Inc. and/or its affiliates in the United States and other countries, and may not be used without written permission. Denodo and the Denodo logo are trademarks or registered trademarks of Denodo Technologies. All other trademarks are the property of their respective owners. John Wiley & Sons, Ltd., is not associated with any product or vendor mentioned in this book. LIMIT OF LIABILITY/DISCLAIMER OF WARRANTY: WHILE THE PUBLISHER AND AUTHOR HAVE USED THEIR BEST EFFORTS IN PREPARING THIS BOOK, THEY MAKE NO REPRESENTATIONS OR WARRANTIES WITH RESPECT TO THE ACCURACY OR COMPLETENESS OF THE CONTENTS OF THIS BOOK AND SPECIFICALLY DISCLAIM ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
    [Show full text]