* Your assessment is very important for improving the workof artificial intelligence, which forms the content of this project
Download StudentGuide
Open Database Connectivity wikipedia , lookup
Microsoft Jet Database Engine wikipedia , lookup
Entity–attribute–value model wikipedia , lookup
Team Foundation Server wikipedia , lookup
Functional Database Model wikipedia , lookup
Relational model wikipedia , lookup
Clusterpoint wikipedia , lookup
Object-relational impedance mismatch wikipedia , lookup
Microsoft SQL Server wikipedia , lookup
Student Guide Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Part #EDB315-90-1242-10 I Notice Copyright ©2000 Sybase, Inc. All rights reserved. No part of this publication may be reproduced, transmitted, or translated in any form or by any means, electronic, mechanical, manual, optical or otherwise, without prior written permission from Sybase, Inc. ® indicates registration in the United States of America. Sybase Trademarks Sybase, SYBASE (logo), ADA Workbench, Adaptable Windowing Environment, Adaptive Component Architecture, Adaptive Server, Adaptive Server Anywhere, Adaptive Server Enterprise, Adaptive Server Enterprise Monitor, Adaptive Server Enterprise Replication, Adaptive Server Everywhere, Adaptive Server IQ, Adaptive Warehouse, AnswerBase, Application Manager, AppModeler, APT Workbench, APT-Build, APT-Edit, APT-Execute, APT-FORMS, APT-Translator, APT-Library, ASEP, Backup Server, BayCam, Bit-Wise, Certified PowerBuilder Developer, Certified SYBASE Professional, Certified SYBASE Professional Logo, ClearConnect, Client-Library, Client Services, CodeBank, Column Design, ComponentPack, Connection Manager, CSP, Data Pipeline, Data Workbench, DataArchitect, Database Analyzer, DataExpress, DataServer, DataWindow, DB -Library, dbQueue, Developers Workbench, Direct Connect Anywhere, DirectConnect, Distribution Director, Electronic Case Management, Embedded SQL, EMS, Enterprise Application Server, Enterprise Application Studio, Enterprise Client/ Server, Enterprise Connect, Enterprise Data Studio, Enterprise Manager, Enterprise SQL Server Manager, Enterprise Work Architecture, Enterprise Work Designer, Enterprise Work Modeler, EWA, First Impression, Formula One, Gateway Manager, GeoPoint, ImpactNow, InfoMaker, Information Anywhere, Information Everywhere, InformationConnect, InstaHelp, InternetBuilder, iScript, Jaguar CTS, jConnect for JDBC, KnowledgeBase, Logical Memory Manager, MainframeConnect, Maintenance Express, MAP, MDI Access Server, MDI Database Gateway, media.splash, MetaWorks, MethodSet, MySupport, Net-Gateway, Net-Library, NetImpact, Next Generation Learning, O DEVICE, OASiS, OASiS logo, ObjectConnect, ObjectCycle, OmniConnect, OmniSQL Access Module, OmniSQL Toolkit, Open Client, Open ClientConnect, Open Client/ Server, Open Client/Server Interfaces, Open Gateway, Open Server, Open ServerConnect, Open Solutions, Optima++, Partnerships that Work, PB-Gen, PC APT Execute, PC DB-Net, PC Net Library, Power++, PowerJ, Power Through Knowledge, power.stop, PowerAMC, PowerBuilder, PowerBuilder Foundation Class Library, PowerDesigner, PowerDimensions, PowerDynamo, PowerScript, PowerSite, PowerSocket, Powersoft, PowerStage, PowerStudio, PowerTips, Powersoft Portfolio, Powersoft Professional, PowerWare Desktop, PowerWare Enterprise, ProcessAnalyst, Report Workbench, Report-Execute, Replication Agent, Replication Driver, Replication Server, Replication Server Manager, Replication Toolkit, Resource Manager, RW-DisplayLib, RW-Library, S Designor, S-Designor, SAFE, SAFE/PRO, SDF, Secure SQL Server, Secure SQL Toolset, Security Guardian, SKILS, smart.partners, smart.parts, smart.script, SQL Advantage, SQL Anywhere, SQL Anywhere Studio, SQL Code Checker, SQL Debug, SQL Edit, SQL Edit/TPU, SQL Everywhere, SQL Modeler, SQL Remote, SQL Server, SQL Server Manager, SQL SMART, SQL Toolset, SQL Server/CFT, SQL Server/DBM, SQL Server SNMP Sub Agent, SQL Station, SQLJ, STEP, SupportNow, Sybase Central, Sybase Client/Server Interfaces, Sybase Development Framework, Sybase Financial Server, Sybase Gateways, Sybase Learning Connection, Sybase MPP, Sybase SQL Desktop, Sybase SQL Lifecycle, Sybase SQL Workgroup, Sybase Synergy Program, Sybase Virtual Server Architecture, Sybase User Workbench, SybaseWare, SyberAssist, SyBooks, System 10, System 11, System XI (logo), SystemTools, Tabular Data Stream, The Enterprise Client/Server Company, The Extensible Software Platform, The Future Is Wide Open, The Learning Connection, The Model For Client/Server Solutions, The Online Information Center, Transact-SQL, Translation Toolkit, Turning Imagination Into Reality, UltraLite, UNIBOM, Unilib, Uninull, Unisep, Unistring, URK Runtime Kit for UniCode, Viewer, Visual Components, VisualSpeller, VisualWriter, VQL, WarehouseArchitect, Warehouse Studio, Warehouse WORKS, Watcom, Watcom SQL, Watcom SQL Server, Web.PB, Web.SQL, WebSights, Web Viewer, WorkGroup SQL Server, XA-Library, XA-Server and XP Server are trademarks of Sybase, Inc. or its subsidiaries. All other company and product names used herein may be the trademarks or registered trademarks of their respective companies. Restricted Rights Legend Use, duplication or disclosure by the Government is subject to restrictions set forth in subparagraph (c)(1)(ii) of DFARS 52.227-7013 for the DOD and as set forth in FAR 52.227-19(a)-(d) for civilian agencies. Sybase, Inc., 6475 Christie Avenue, Emeryville, CA 94608 How to Use This Guide Student Guide The pages of this Student Guide are divided into two sections: a slide and a set of student notes. Your instructor will project the slide during class. The student notes provide additional notes to accompany the slide. Putting It All Together Some pages include only a code fragment or a code summary. They are provided for your reference to help illustrate how the commands work in sequence. Use the code fragments to complete the labs. The instructor may or may not display these sections Icon Samples Caution—Possible damage to equipment, data, or software Critical note—Very important piece of information that should definitely be read Note—Information that expands upon or supplements the information in the main text NT—Information specific to the Windows NT platform Question Recovery Tip—A suggestion for improving backup and recovery. Tip—Best practice or "tips and tricks" information TryIt UNIX—Information specific to the UNIX platform We Want to Hear From You Feedback Sybase welcomes your feedback on our course materials. This includes corrections as well as suggestions for improvements. Please mark typographical errors, formatting errors, errors of fact, or areas that need clarification and send copies of those pages to the Sybase Education Products and Technology Group (EPTG). Be sure to include your name, phone number, address and/or e-mail address so that we can reach you should we need clarification about your concerns. Sybase EPTG address Sybase, Inc. Education Products and Technology Group 6475 Christie Avenue Emeryville, CA 94608 USA Sybase EPTG fax Sybase EPTG E-mail Fax (510) 922-3559 [email protected] Administering Adaptive Server IQ for the Data Warehouse Student Guide Module 1 Overview Module 2 Adaptive Server IQ Product When to Use Adaptive Server IQ (ASIQ)?. Module Overview .................................................................................................. 1-1 Using ASIQ to Split DSS and OLTP .......................................................................................... .............................................. 1-3 Distributed Data Mart ........................................................................................... 1-4 Data Warehouse .................................................................................................... 1-5 What Is ASIQ? ...................................................................................................... 1-6 What ASIQ Is Not ................................................................................................. 1-7 Advantages of ASIQ: Overview ............................................................................ 1-8 Advantages of ASIQ: Speed .................................................................................. 1-9 Advantages of ASIQ: Economy .......................................................................... 1-10 Advantages of ASIQ: Flexibility ......................................................................... 1-11 What Principles Are at Work? ............................................................................. 1-13 Column-Wise Data Structures ............................................................................. 1-14 Bit-Wise Indexing................................................................................................ 1-15 ASIQ Multiplexing .............................................................................................. 1-18 Benefits of ASIQ ................................................................................................. 1-19 Summary ............................................................................................................. 1-20 Lab 1: ASIQ Product Overview .......................................................................... 1-21 Architecture and Terminology Module Overview .................................................................................................. 2-3 ASIQ Platforms ..................................................................................................... 2-4 Module Map .......................................................................................................... 2-5 Adaptive Server Anywhere and Adaptive Server IQ ............................................. 2-6 Adaptive Server IQ Database Server .................................................................... 2-7 ASIQ Server and Database (Without Multiplex) .................................................. 2-8 IQ Main Store ....................................................................................................... 2-9 Catalog Store ....................................................................................................... 2-10 IQ Temporary Store............................................................................................. 2-13 IQ Message Log .................................................................................................. 2-14 Putting It All Together...ASIQ Database ............................................................. 2-15 Module Map ........................................................................................................ 2-16 ASIQ Tables ........................................................................................................ 2-17 Utility Database ................................................................................................... 2-18 ASIQ Indexes ...................................................................................................... 2-19 ASIQ Tables and ASIQ Indexes .......................................................................... 2-20 interfaces File and ASIQ Connectivity ................................................................ 2-21 ASIQ Architecture .............................................................................................. 2-22 ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 TOC-1 Table of Contents Summary ................ Lab 2: Architecture Module 3 2-23 224 ASIQ Environment and Installation Module Overview .................................................................................................. 3-1 Module Map .......................................................................................................... 3-2 Disk Space ............................................................................................................ 3-3 Virtual Memory ..................................................................................................... 3-4 Swap ...................................................................................................................... 3-5 Basic Configuration Recommendations ................................................................ 3-6 Hardware Recommendations................................................................................. 3-7 Module Map .......................................................................................................... 3-8 Before Installing Software on UNIX .................................................................... 3-9 Preparing for ASIQ Installation on the UNIX Platform ....................................... 3-10 Installing Adaptive Server IQ .............................................................................. 3-11 Setting Environment Variables ............................................................................ 3-12 Starting the ASIQ Server - UNIX ...................................................................... 3-15 Starting the ASIQ Server -Simple Method ...................................................... 3-16 Starting the ASIQ Server - UNIX ...................................................................... 3-17 Server Configuration File.................................................................................... 3-18 Stopping the Server ............................................................................................. 3-19 Preparing for ASIQ Installation on the NT Platform ........................................... 3-20 Installing ASIQ Server Components .................................................................... 3-21 Starting the Server ............................................................................................... 3-22 Stopping the Server ............................................................................................. 3-23 Installing ASIQ Server Client Components ........................................................ 3-24 Module Map ........................................................................................................ 3-25 Validating the ASIQ Environment ...................................................................... 3-26 Lab 3-1: Installation ........................................................................................... 3-27 Module Map ........................................................................................................ 3-28 Setting Up ODBC ............................................................................................... 3-29 Connection to ASIQ using DBISQL ................................................................... 3-36 Starting DBISQL - GUI ...................................................................................... 3-37 Ready to Connect ................................................................................................ 3-38 Interactive SQL ................................................................................................... 3-39 Connect Using Command Line DBISQL ............................................................ 3-40 Connecting Through Sybase Central ................................................................... 3-41 Sybase Central..................................................................................................... 3-42 Sybase Central Features ...................................................................................... 3-43 Module Map ........................................................................................................ 3-44 Database Configuration File for Open Client 12 ................................................. 3-45 Setting Up JDBC and Open Client ...................................................................... 3-46 Setting Up JDBC and Open Client ...................................................................... 3-48 Setting Up JDBC ................................................................................................. 3-49 Connect Using ISQL ........................................................................................... 3-50 ISQL Versus DBISQL......................................................................................... 3-51 sp_iqstatus ........................................................................................................... 3-52 TOC-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Table of Contents Running sp_iqstatus Command to Check ASIQ .................................................. 3-53 Summary of Installation Steps ............................................................................ 3-54 Lab 3-2: Connectivity ...................................................................................... 3-55 Module 4 Creating Databases Module Overview .................................................................................................. 4-1 Database Review ................................................................................................... 4-2 Database Overview................................................................................................ 4-3 Creating a Database .............................................................................................. 4-4 Step 1: Select the Device Type .............................................................................. 4-5 Step 2: Estimate the Database Size ........................................................................ 4-6 Step 3: Create the Database .................................................................................. 4-7 Files Allocated When Creating Database .............................................................. 4-8 Full Syntax ............................................................................................................ 4-9 Command Options .............................................................................................. 4-10 Create Database: Example 1 ................................................................................ 4-14 Create Database: Example 2 ............................................................................... 4-15 Creating Databases: Sybase Central.................................................................... 4-16 Before Starting the Server with the New Database .............................................. 4-18 Command-Line Switches .................................................................................... 4-19 Other Recommended Switches............................................................................ 4-20 Command-Line or Configuration File Switches .................................................. 4-21 Communication Protocols.................................................................................... 4-22 Communication Protocol Switches...................................................................... 4-23 Starting the Server with the New Database ......................................................... 4-24 Creating a New DSN .......................................................................................... 4-25 Viewing the New Database: Sybase Central ........................................................ 4-26 sp_iqstatus ........................................................................................................... 4-27 Checking the Database with sp_iqstatus .............................................................. 4-28 Enlarging a Database .......................................................................................... 4-29 Enlarging a Database: Sybase Central ................................................................ 4-30 Decreasing a Database ........................................................................................ 4-31 Dropping a Database ........................................................................................... 4-32 Other Useful Stored Procedures .......................................................................... 4-33 sp_iqdbsize .......................................................................................................... 4-34 Summary ............................................................................................................. 4-35 Lab 4: Databases ............................................................................................... 4-36 Module 5 ASIQ Index Types and Datatypes Module Overview .................................................................................................. 5-1 Module Map .......................................................................................................... 5-2 Types of Indexes Used by Typical RDBMSs ........................................................ 5-3 ASIQ's Bitmap Indexes ......................................................................................... 5-4 Review: ASIQ Index Characteristics ..................................................................... 5-5 ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 TOC-3 Table of Contents Review: Four Basic Index Types ........................................................................... 5-6 Fast Projection (FP) .............................................................................................. 5-7 Low Fast (LF) ..................................................................................................... 5-10 High Non Group (HNG)...................................................................................... 5-11 High Group (HG) ................................................................................................ 5-12 Generic Method for Indexing Columns ............................................................... 5-13 Combining Index Types....................................................................................... 5-14 Fast Indexes ......................................................................................................... 5-15 Step 1: By Default, an FP Index Is on Each Column ........................................... 5-16 Step 2: Create LF on Low-Cardinality Columns ................................................ 5-17 Step 3: Create HG on High-Cardinality Columns ............................................... 5-18 Step 4: Create HNG, If Needed .......................................................................... 5-19 Case Study........................................................................................................... 5-20 Case Study: Solutions ......................................................................................... 5-21 Module Map ........................................................................................................ 5-23 ASIQ Data Types ................................................................................................ 5-24 User-Defined Datatypes ...................................................................................... 5-27 Summary ............................................................................................................. 5-28 Lab 5: ASIQ Indexing and Datatypes ............................................................... 5-29 Module 6 Creating Tables and Indexes Module Overview .................................................................................................. 6-1 Steps for Deploying an ASIQ Installation ............................................................ 6-2 Module Map .......................................................................................................... 6-3 Create Tables in the ASIQ Database ...................................................................... 6-4 CREATE TABLE .................................................................................................. 6-5 Building Upon CREATE TABLE........................................................................... 6-6 CREATE TABLE - IQ UNIQUE .......................................................................... 6-7 CREATE TABLE - UNIQUE ................................................................................ 6-8 CREATE TABLE - PRIMARY KEY .................................................................... 6-9 Building Upon CREATE TABLE......................................................................... 6-10 FOREIGN KEY Constraint................................................................................. 6-11 Syntax: CREATE TABLE .................................................................................... 6-13 CREATE TABLE ................................................................................................ 6-14 Creating a Table with Sybase Central .................................................................. 6-16 Sybase Central: Steps 1-3 ................................................................................... 6-17 Sybase Central: Steps 4-6 ................................................................................... 6-18 Sybase Central..................................................................................................... 6-19 Viewing a Table................................................................................................... 6-2 1 Altering Tables .................................................................................................... 6-2 2 ALTER TABLE .................................................................................................. 6-2 3 TRUNCATE TABLE........................................................................................... 6-2 4 DROP TABLE..................................................................................................... 6-2 5 Module Map ........................................................................................................ 6-2 6 Local Temporary Tables: Method 1 .................................................................... 6-2 7 Local Temporary Tables: Method 2 .................................................................... 6-2 8 Module Map ........................................................................................................ 6-2 9 TOC-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Table of Contents Global Temporary Tables .................................................................................... 6-30 Module Map ........................................................................................................ 6-31 View: Defined ..................................................................................................... 6-32 Creating a View: Benefits ................................................................................... 6-33 View: Using Partitioned Tables ............................................................................ 6-34 CREATE VIEW .................................................................................................. 6-35 Views for Performance ........................................................................................ 6-36 Steps for Deploying an ASIQ Installation .......................................................... 6-37 Create the ASIQ Indexes .................................................................................... 6-38 Review: Index Types ........................................................................................... 6-39 Four Options for Creating Indexes ...................................................................... 6-40 CREATE INDEX: Syntax and Example .............................................................. 6-41 CREATE INDEX: Sybase Central ...................................................................... 6-42 CREATE INDEX: Restrictions ........................................................................... 6-46 Creating Indexes in Parallel ................................................................................. 6-47 Viewing ASIQ Indexes with sp_iqindex .............................................................. 6-49 Dropping Indexes ................................................................................................ 6-50 Create and Maintain Scripts ................................................................................ 6-51 Summary ............................................................................................................. 6-52 Lab 6: Creating Tables and Indexes..................................................................... 6-53 Module 7 ASIQ Memory Configuration Module Overview .................................................................................................. 7-1 Sybase ASIQ Memory Components ...................................................................... 7-2 Server Memory...................................................................................................... 7-3 Buffers, Page Size, and Blocks ............................................................................. 7-4 Buffer Caches ........................................................................................................ 7-5 Why Tune Shared Buffer Caches?......................................................................... 7-6 Main Buffer Cache ................................................................................................ 7-7 Temporary Buffer Cache ....................................................................................... 7-8 Viewing Buffer Cache Size.................................................................................... 7-9 "Active" Users ..................................................................................................... 7-10 Strategy for Sizing Caches .................................................................................. 7-11 Memory: The Big Picture ................................................................................... 7-12 Operating System Memory and Other Applications ............................................ 7-13 ASIQ Server ........................................................................................................ 7-14 ASIQ Memory Overhead .................................................................................... 7-15 Side Note on Setting Database Options .............................................................. 7-17 load_memory_MB option ................................................................................... 7-18 ASIQ Main and Temp Buffer Caches .................................................................. 7-19 Strategy for Sizing Buffer Caches ....................................................................... 7-20 Calculating Memory for Caches on UNIX .......................................................... 7-2 1 Calculating Memory for Caches on NT .............................................................. 7-2 2 Query Memory Requirements: Read-Only........................................................... 7-2 3 Strategy for Sizing Caches .................................................................................. 7-2 4 Setting Buffer Caches.......................................................................................... 7-2 5 Viewing the New Buffer Caches .......................................................................... 7-28 ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 TOC-5 Table of Contents Memory and Swap Usage ................................................................................... 7-29 Memory Performance.......................................................................................... 7-30 Summary ............................................................................................................. 7-31 Lab 7: Memory Configuration ............................................................................ 7-32 Module 8 Loading Data from Files Module Overview .................................................................................................. 8-1 Data Sources.......................................................................................................... 8-2 Table Loading ....................................................................................................... 8-3 Data Loading ......................................................................................................... 8-4 Simple Example: Flat-File Load............................................................................ 8-5 Adding Rows with LOAD TABLE ........................................................................ 8-6 LOAD TABLE Command: Partial Syntax ............................................................ 8-7 Module Map .......................................................................................................... 8-8 load-specification / column-spec .......................................................................... 8-9 column-spec ........................................................................................................ 8-10 Inserting Using Fixed-Width Field Specification ................................................ 8-11 Inserting Variable-Length Fields ........................................................................ 8-12 Example: Loading from a Character File ............................................................. 8-13 Date and Datetime Considerations ...................................................................... 8-14 A Word About NULL ......................................................................................... 8-16 Module Map ........................................................................................................ 8-17 FROM Clause...................................................................................................... 8-18 Module Map ........................................................................................................ 8-19 load-options ........................................................................................................ 8-20 DELIMITED BY Option .................................................................................... 8-21 Inserting Variable-Length Fields ........................................................................ 8-22 QUOTES/ESCAPES Options ............................................................................. 8-23 WITH CHECKPOINT Option ............................................................................ 8-24 Putting It Together ............................................................................................... 8-25 PREVIEW load-option - Input Layout Description ............................................. 8-26 ROW DELIMITED BY load_option ................................................................... 8-27 Loading in Parallel .............................................................................................. 8-28 More Complex LOAD TABLE Example ............................................................ 8-29 Module Map ........................................................................................................ 8-30 What Happens During a load Session? ................................................................ 8-3 1 Notification Messages ......................................................................................... 8-3 2 Transaction Processing and LOAD TABLE ........................................................ 8-3 3 Deleting Data ...................................................................................................... 8-3 4 DELETE Statement............................................................................................. 8-3 5 DELETE, then LOAD TABLE ............................................................................ 8-3 6 UPDATE Command ............................................................................................ 8-3 7 Summary ............................................................................................................. 8-3 8 Lab 8: Loading Data from Files .......................................................................... 8-3 9 TOC-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Table of Contents Module 9 Advanced Data Loading from Files Module Overview .................................................................................................. 9-1 Review: Options for Table Loading ...................................................................... 9-2 Review: LOAD TABLE Command ...................................................................... 9-3 Advanced Insert Load Options .............................................................................. 9-4 Module Map .......................................................................................................... 9-5 Multifile Load ....................................................................................................... 9-6 Example: Multifile Load ....................................................................................... 9-8 Module Map .......................................................................................................... 9-9 Partial-Width Loads............................................................................................. 9-10 What Is a ROWID? ............................................................................................. 9-11 Partial-Width Loads ............................................................................................ 9-12 Example: Partial-Width Loads ............................................................................ 9-14 Example: Partial-Width Load - The Right Way ................................................... 9-15 Example: Partial-Width Load - The Wrong Way ................................................. 9-17 Module Map ........................................................................................................ 9-19 Adding dbspaces During a Load.......................................................................... 9-20 Good Loading Practices ...................................................................................... 9-21 Summary ............................................................................................................. 9-22 Lab 9: Advanced Loading Data from File .......................................................... 9-23 Module 10 Loading Data Using the INSERT Command Module Overview................................................................................................ 10-1 Table Loading ...................................................................................................... 10-2 INSERT from SELECT Command ...................................................................... 10-3 INSERT VALUES Command .............................................................................. 10-4 Module Map ........................................................................................................ 10-5 Partial-Width Inserts ............................................................................................ 10-6 Example: Partial-Width Insert - The Right Way ............................................... 10-7 Module Map ........................................................................................................ 10-9 Inserting from the IQ Main Store ................................................................... 10-10 Module Map ...................................................................................................... 10-13 Inserting Directly from a Foreign Database ....................................................... 10-14 Using CIS .......................................................................................................... 10-17 Summary ........................................................................................................... 10-18 Lab 10: Loading Data Using the insert Command .......................................... 10-19 Module 11 Using ASIQ Module Overview ................................................................................................ 11-1 ASIQ SQL ........................................................................................................... 11-2 Review: SELECT Statement ............................................................................... 11-3 SELECT Statement ............................................................................................. 11-4 Module Map ........................................................................................................ 11-6 ASIQ-Specific SQL Features .............................................................................. 11-7 ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 TOC-7 Table of Contents KEY JOIN ........................................................................................................... 11-8 NATURAL JOIN................................................................................................. 11-9 OUTER JOIN .................................................................................................... 11-10 Expressions in Subqueries ................................................................................. 11-11 IF Condition ...................................................................................................... 11-12 CASE Statement ............................................................................................... 11-13 A Word on Quotes ............................................................................................ 11-14 Module Map ...................................................................................................... 11-15 ASIQ Numeric Functions .................................................................................. 11-16 ASIQ String Functions ...................................................................................... 11-17 ASIQ Date and Time Functions......................................................................... 11-18 ASIQ Datatype Conversion Functions............................................................... 11-19 Additional ASIQ Functions............................................................................... 11-20 Module Map ...................................................................................................... 11-21 Exporting Data from ASIQ................................................................................ 11-22 Exporting Data Using Redirection .................................................................... 11-23 Exporting Data Using Redirection .................................................................... 11-24 Exporting Data Using Data Extraction .............................................................. 11-25 Options for Data Extraction .............................................................................. 11-26 Data Extraction ................................................................................................. 11-28 Summary ........................................................................................................... 11-29 Lab 11: Using ASIQ ...................................................................................... 11-30 Module 12 ASIQ Operational Data Administration Module Overview ................................................................................................ 12-1 Module Map ........................................................................................................ 12-2 Transaction Processing ....................................................................................... 12-3 What Is a Transaction? ........................................................................................ 12-4 Transaction Commands ...................................................................................... 12-5 Chained and Unchained Transaction Modes ....................................................... 12-8 Completing Transactions ..................................................................................... 12-9 Module Map ...................................................................................................... 12-10 Locking ............................................................................................................. 12-11 Locks forDML ................................................................................................. 12-12 Locks for DDL .................................................................................................. 12-13 ANSI Isolation Levels........................................................................................ 12-14 Module Map ...................................................................................................... 12-15 Snapshot Versioning .......................................................................................... 12-16 Versioning Level ............................................................................................... 12-17 Table Versioning................................................................................................ 12-18 Versioning Example .......................................................................................... 12-19 Option to COMMIT After Every SELECT ...................................................... 12-24 ODBC AutoPreCommit .................................................................................... 12-25 Snapshot Versioning: Issues .............................................................................. 12-26 Module Map ...................................................................................................... 12-27 Data Security ..................................................................................................... 12-28 Users.................................................................................................................. 12-29 TOC-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Table of Contents Users and Groups .............................................................................................. 12-30 Special User ...................................................................................................... 12-31 Creating Users ................................................................................................... 12-32 Creating Users with Sybase Central .................................................................. 12-33 Special Groups .................................................................................................. 12-35 Creating Groups ................................................................................................ 12-36 Adding a User to a Group ................................................................................. 12-37 Table and View Permissions .............................................................................. 12-38 Stored Procedure Permissions .......................................................................... 12-39 REVOKE Statement ......................................................................................... 12-40 Permissions Hierarchy ...................................................................................... 12-41 Database Object Names and Prefixes ................................................................ 12-42 Summary ........................................................................................................... 12-43 Lab 12: ASIQ Operational Data Administration ............................................... 12-44 Module 13 Joins Module Overview ................................................................................................ 13-1 Types of Joins ...................................................................................................... 13-2 Ad-Hoc Joins ....................................................................................................... 13-3 When to Use Ad-Hoc Joins ................................................................................ 13-4 When to Create a Join Index................................................................................ 13-5 Ad-Hoc Joins Versus Join Indexes ...................................................................... 13-6 Creating a Join Index........................................................................................... 13-7 Step 1: Create Tables ........................................................................................... 13-8 Step 2: Define the Relationships.......................................................................... 13-9 Join Hierarchy ................................................................................................... 13-10 Types of Join Hierarchies .................................................................................. 13-11 Entity-Relationship Diagram ............................................................................ 13-12 Join Hierarchy with the Top Table .................................................................... 13-13 Creating a Join Index......................................................................................... 13-14 Step 3: Create the Indexes .................................................................................. 13-15 Step 4: Load Data.............................................................................................. 13-16 Creating a Join Index......................................................................................... 13-17 Step 5: Create the Join Index ............................................................................ 13-18 Creating a Join Index......................................................................................... 13-22 Step 6: Synchronize Join Indexes ...................................................................... 13-23 Multiple-Table Join Example ............................................................................. 13-25 To Create the Join Index.................................................................................... 13-26 Rules for Join Indexes ....................................................................................... 13-27 Estimating Join Index Size ................................................................................ 13-28 Actual Join Index Size ...................................................................................... 13-29 Dropping a Join Index ....................................................................................... 13-30 Data Modification in a Join Index ..................................................................... 13-31 How Join Indexes Are Used .............................................................................. 13-32 Summary ........................................................................................................... 13-33 Lab 13: Joins ................................................................................................... 13-34 ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 TOC-9 Table of Contents Module 14 Monitoring and Troubleshooting Module Overview ................................................................................................ 13-1 Module Map ........................................................................................................ 13-2 Monitoring Users................................................................................................. 13-3 Monitoring Loads/Deletes/Inserts........................................................................ 13-4 Monitoring Loading Messages ............................................................................ 13-5 Monitoring Load Messages ................................................................................ 13-7 Monitoring the Database ..................................................................................... 13-8 dbcc_option ....................................................................................................... 13-12 Monitoring the Database ................................................................................... 13-14 Monitoring Buffer Caches ................................................................................. 13-17 Stopping the Buffer Cache Monitor .................................................................. 13-21 System Utilities .................................................................................................. 13-22 Module Map ...................................................................................................... 13-23 Troubleshooting Fields ...................................................................................... 13-24 ASIQ Server Won't Start .................................................................................. 13-25 User Cannot Access the Database or Database Objects ........................................................................................... 13-26 Database Fills Up During the Load ................................................................... 13-27 Processing Slows Down or Hangs ..................................................................... 13-28 Reporting Problems to Technical Support ........................................................ 13-29 Summary ........................................................................................................... 13-30 Lab 14 -Monitoring and Troubleshooting ........................................................ 13-31 Module 15 Performance and Tuning Module Overview .......................................................................................................... 15-1 Module Map.................................................................................................................... 15-2 IQ Query Engine ............................................................................................................ 15-3 IQ Query Engine Architecture ..................................................................................... 15-5 IQ Query Optimizer ....................................................................................................... 15-6 IQ Query Optimizer ....................................................................................................... 15-9 Module Map..................................................................................................................15-10 Choosing Correct Index Types .................................................................................. 15-11 Database Options for Performance ............................................................................15-14 IQ Query Plans .............................................................................................................15-15 IQ Query Tree ...............................................................................................................15-16 IQ Query Plans .............................................................................................................15-17 IQ Query Plan Detail ...................................................................................................15-23 QUERY_ROWS_RETURNED_LIMIT .................................................................. 15-24 NOEXEC and ROWCOUNT Options ......................................................................15-25 IQ Query Plan -Elements ............................................................................................15-26 More Query Options ....................................................................................................15-28 IQ Query Performance ................................................................................................15-29 Module Map..................................................................................................................15-30 Loading Data from a Fixed-Length ASCII Flat File ............................................ 15-31 TOC-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Table of Contents Using Disk Striping ........................................................................................... 15-32 Using Multiple dbspaces ................................................................................... 15-33 Spreading Access Across Separate Disks .......................................................... 15-34 Improving INSERT/UPDATE/DELETE Performance ....................................... 15-35 Memory Allocation ........................................................................................... 15-36 Limiting Number of Active Queries on the IQ Server ....................................... 15-38 Summary ........................................................................................................... 15-39 Lab 15: Performance and Tuning ...................................................................... 15-40 Module 16 Backup and Restore Module Overview ................................................................................................ 16-1 Backup Features .................................................................................................. 16-2 Archive Devices .................................................................................................. 16-3 Backup ................................................................................................................ 16-4 Types of Backups ................................................................................................ 16-5 Running a Backup ............................................................................................... 16-6 BACKUP DATABASE Syntax ........................................................................... 16-7 Example: Simple Backup .................................................................................... 16-8 SIZE and STACKER Options.............................................................................. 16-9 Example: Incremental Backup .......................................................................... 16-10 Backup: Notes and Restrictions ........................................................................ 16-11 Validating Your Database .................................................................................. 16-12 sp_iqcheckdb..................................................................................................... 16-13 Restore Features ................................................................................................ 16-14 Before You Restore ........................................................................................... 16-15 Restore Database ............................................................................................... 16-16 Restore Database: Full Restore .......................................................................... 16-17 Moving Database Files ...................................................................................... 16-18 Restore Database ............................................................................................... 16-20 Restore Database: Notes and Restrictions ......................................................... 16-21 ASIQ Backup and Restore Performance ........................................................... 16-22 Estimating Dump Size ...................................................................................... 16-23 DBLOG Utility .................................................................................................. 16-24 Option for Backing Up a Large Database .......................................................... 16-25 Summary ........................................................................................................... 16-26 Lab 16: Backup and Restore ............................................................................ 16-27 Module 17 Multiplexing Overview Module Overview ................................................................................................ 17-1 What Is IQ Multiplexing? ................................................................................... 17-2 Multiplex Architecture .........................................................................................17-3 Multiplex Features ...............................................................................................17-4 ASIQ Architecture (Simplex) ............................................................................. 17-6 ASIQ Architecture (Multiplex)............................................................................ 17-7 Write and Query Servers ...................................................................................... 17-8 Communication between Servers ........................................................................ 17-9 ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 TOC-11 Table of Contents Multiplex Operating Modes .............................................................................. 17-10 IQM Advantages ............................................................................................... 17-11 Summary ........................................................................................................... 17-12 Lab 17: Multiplexing Overview ........................................................................ 17-13 Module 18 ASIQ Multiplex Hardware Module Overview ................................................................................................ 18-1 Module Map ........................................................................................................ 18-2 Storage Basics ..................................................................................................... 18-3 RAID Basics........................................................................................................ 18-4 RAID Diagram .................................................................................................... 18-5 RAID Levels........................................................................................................ 18-6 RAID Striping ..................................................................................................... 18-7 RAID Connectivity.............................................................................................. 18-8 Module Map ........................................................................................................ 18-9 Configuring Storage .......................................................................................... 18-10 IQM and Shared Disk Farm .............................................................................. 18-11 IQ Multiplex Hardware ... Putting it together .................................................... 18-12 Summary ........................................................................................................... 18-13 There is no lab for this module .......................................................................... 18-14 Module 19 Creating a Multiplex Database Module Overview .......................................................................................................... 19-1 Steps to Set up Multiplex .............................................................................................. 19-2 Step 1 - Create the Write Server .................................................................................. 19-3 Create the IQ Write Server ........................................................................................... 19-4 Steps t ........................................................................................... o Set up Multiplex19-11 Step 2 - Create Reader (Query) Servers ...................................................................19-12 Create Query Server ....................................................................................................19-13 Directory Structure ......................................................................................................19-18 Steps to Set up Multiplex ............................................................................................ 19-19 Step 3 - Synchronize ....................................................................................................19-20 Synchronize ..................................................................................................................19-21 What we have so far .....................................................................................................19-22 Steps to Set up Multiplex ............................................................................................ 19-23 Why Add A Temp Store?............................................................................................19-24 Step 4 - Add Temp Store for Writer ..........................................................................19-25 Add Temp Store for Writer .........................................................................................19-26 Steps to Set up Multiplex ............................................................................................ 19-30 Step 5 - Add Main IQ Store dbspaces ........................................................................19-31 Start Server in Simplex Mode ................................................................................... 19-32 Add Main IQ Store dbspaces ......................................................................................19-33 Add Main Store Dbspaces .......................................................................................... 19-38 Stop the Writer Server .................................................................................................19-39 TOC-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Table of Contents Steps to Set up Multiplex .................................................................................. 19-40 Step 6 - Add Temp Store for the Query Server................................................... 19-41 Summary ........................................................................................................... 19-42 There is no lab for this module .......................................................................... 19-43 Module 20 Multiplex Operations Module Overview ................................................................................................ 20-1 Working in the Multiplex Environment ............................................................... 20-2 Creating Database Objects .................................................................................. 20-3 Setting Memory .................................................................................................. 20-4 Loading Data ....................................................................................................... 20-5 Running Queries.................................................................................................. 20-6 Specifying Database Options .............................................................................. 20-7 Postsync.sql Script .............................................................................................. 20-8 Working in the Multiplex Environment ............................................................... 20-9 Setting Startup Parameters ................................................................................ 20-10 Starting and Stopping ........................................................................................ 20-11 Select the Start Mode ........................................................................................ 20-12 Stopping Multiplex Server ................................................................................ 20-13 Stopping Individual Servers .............................................................................. 20-14 Managing Servers .............................................................................................. 20-15 Restarting Servers.............................................................................................. 20-16 Working in the Multiplex Environment ............................................................. 20-17 Adding and Dropping Dbspaces ....................................................................... 20-18 To Add A Permanent (Main) Dbspace .............................................................. 20-19 To Create a Temporary Dbspace ........................................................................ 20-20 To Drop a Main or Temporary Dbspace............................................................. 20-21 Working in the Multiplex Environment ............................................................. 20-22 Backup the Multiplex ........................................................................................ 20-23 Restore the Multiplex ........................................................................................ 20-24 Summary ........................................................................................................... 20-25 There is no lab for this module .......................................................................... 20-26 Appendix A Migrating Data from Prior Versions Appendix Overview .............................................................................................. A-1 Why Is Data Migration Necessary? ...................................................................... A-2 Migration Steps ..................................................................................................... A-3 Step 1 - Install Version 12.0.................................................................................. A-4 Step 2 - Create 12.0 Database............................................................................... A-5 Method 1 ............................................................................................................... A-6 Method 2 ............................................................................................................... A-7 IQ CREATE ASIQ TEMPLATE ........................................................................... A-8 Edit Scripts ............................................................................................................ A-9 Database Creation Script ..................................................................................... A-10 ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 TOC-13 Table of Contents Module Map ........................................................................................................ A-15 Migration Scripts ................................................................................................. A-16 Data Extract Script .............................................................................................. A-17 Data Load Script ................................................................................................. A-19 Editing Scripts ..................................................................................................... A-21 Running Scripts ................................................................................................... A-22 Module Map ........................................................................................................ A-23 Load the Data from your Original Source ........................................................... A-24 Module Map ........................................................................................................ A-26 Insert the Data from an Indexspace ..................................................................... A-27 Module Map ........................................................................................................ A-28 Select Data into an ASCII file ............................................................................. A-29 bcp Data into an ASCII file ................................................................................. A-30 Migration Notes .................................................................................................. A-31 Summary ............................................................................................................. A-33 TOC-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 1 Adaptive Server IQ Product Overview Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Module Overview This module will provide a brief overview of Adaptive Server IQ (ASIQ) Objectives After completing this module, you should be able to: ■ List the key advantages of ASIQ ■ Describe the principles at work behind ASIQ ■ Explain what ASIQ is ■ Explain what ASIQ is not ■ This module answers the basic questions about how ASIQ's unique technology can be used for decision support systems (DSSs), data marts, or data warehousing. Note ■ ©2000 Sybase, Inc. ■ This is an introductory module. Later modules discuss the architecture as well as the indexes in greater detail. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 -1 Adaptive Server IQ Product Overview When to Use Adaptive Server IQ (ASIQ)? Decision support system (DSS) Distributed data mart Data warehouse DSS Decision support system. Although some queries will be requested regularly, management often asks for unexpected aggregates of data that traditionally require individualized tuning for each query. Data mart A special-purpose data warehouse focused on a single strategic or efficiency issue. A data mart often serves as a single department's analytical base. Data warehouse Extremely large database encompassing an enterprise-wide set of data. A data warehouse can be used as the source of data for a company's data marts or for direct DSS queries. 1-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Using ASIQ to Split DSS and OLTP Off-Loads DSS Query Burden from an OLTP Engine Splitting DSS and OLTP • Reduces contention between readers and writers Ad-hoc query applications, used in decision support systems • Queries are not predefined • Are often I/O intensive OLTP Online transaction processing involves heavy inserting, updating, and deleting. Typically, queries bring back one row or only a few rows. Indexes are used sparingly and a Database Administrator can tune for the limited types of queries performed. DSS Decision support systems are typically read-only data that has been filtered, preprocessed, scrubbed, or rolled up for analysis. The data may have originated in an OLTP database and may be as new as one day old. Ad-hoc query A query that the system has no prior knowledge of and for which no explicit tuning can therefore be done. Reduce contention Typically, readers block writers and writers block readers. Contention results. Separating scan-intensive DSS users and OLTP users is beneficial to both. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1-3 Adaptive Server IQ Product Overview Distributed Data Mart Specialized Servers for Speciaized Needs Data mart example 1-4 This example shows a number of clients accessing a specialized data mart, depending on the client's needs. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Data Warehouse Centralized Enterprise-Wide Data Warehouse Example ©2000 Sybase, Inc. This example shows a number of clients accessing a central, enterprise-wide data warehouse ASIQ Server. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1-5 Adaptive Server IQ Product Overview What Is ASIQ? A Powerful Ad-Hoc Query Server ■ Designed to dramatically increase the speed of DSS queries performed against large amounts of data ■ Short list of features: • Vertical data storage and compression • Optimized access methods for all types of data • Uses bit-wise storage technology • Ad-hoc query optimizer • Standard open interfaces • Supported by Sybase Central All of the features are discussed in detail in later modules. Access method An access method is really an index that is defined on each column. Sybase Central Database management tool in a graphical user interface. 1-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview What ASIQ s Not An online transaction-processing engine • Use Adaptive Server Enterprise instead A tool for tuning an existing database A server for applications that require real-time updates • Use Adaptive Server Enterprise or Adaptive Server Anywhere instead ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1-7 Adaptive Server IQ Product Overview Advantages of ASIQ: Overview Speed • Designed for ad-hoc queries • Reduced I/O on retrieval • Fast to implement Economy • Set up once for all queries • Excellent data compression characteristics • Reduced disk storage Flexibility • Interoperates with multiple data sources • Works with off-the-shelf query tools Speed Consistently fast response time for complex ad-hoc queries. Accesses only the data relevant to the query, reducing I/O up to 98%. Accelerates iterative analysis and information. Economy Enables Database Administrators (DBAs) to tune data once rather than for each query. Supports a standard relational framework, Sybase's Open Client interfaces, and ODBC, allowing DBAs to leverage existing skills and infrastructure. Provides more answers to more questions for more users, enhancing your productivity. Improves performance without adding hardware. Compresses data, dramatically reducing disk requirements and cost. Flexibility Loading from various data sources, including SQL Server, Adaptive Server, and flat files. Can be directly accessed through OmniConnect, which includes a large number of gateways. Works with a wide range of popular, off-the-shelf query tools, giving users their choice. Handles any database schema, allowing business users to see data their way. 1-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Advantages of ASIQ: Speed Scalability • Handles large amounts of data • Takes advantage of multiple processors for loading and queries • Multiplexing allows a multiple server configuration Speed of loading • Fast loads are a critical success factor for a data warehouse • Indexes can be incrementally loaded or deleted without being dropped and recreated • Can load data while users are querying Scalability example ■ Multiplexing Will be discussed in further detail in later modules. ©2000 Sybase, Inc. When ASIQ query workload increases by 20 times, average ASIQ response time increases by only 5 times. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1-9 Adaptive Server IQ Product Overview Advantages of ASIQ: Economy Saves Disk Space by Storing Only the Index Index sizes are kept small through a variety of data compression technologies The entire database can be fully indexed and made available for ad-hoc queries in less space than it takes to store the raw data Less space Typically 50-100% of the raw data size. The indexes are the data; there is no need for both structures. No summary tables needed Summary tables are typically not needed because ASIQ returns queries so quickly without them. Compact indexes More compact, bit-wise indexing requires less disk space than traditional b-tree indexes. 1-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Advantages of ASIQ: Flexibility Flexible (open systems support) • Integrated with Open Client and Open Server • Integrated with ODBC, JDBC • To the end user and DBA, ASIQ looks just like another RDBMS ( c o n t inued . . .) Note ■ ■ ODBC driver ©2000 Sybase, Inc. The most recent list of tested tools can be found in the Release Bulletin that came with your software. Some of the PC tools are BrioQuery, Business Objects, Forest & Trees, GQL, Holos, InfoMaker, Iridon Panorama, Microsoft Access, MicroStrategy and Cognos. Special ODBC driver ships with ASIQ. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1-11 Adaptive Server IQ Product Overview Advantages of ASIQ: Flexibility Can load data from a variety of sources Client Example 1-12 The graphic above shows that data can be loaded directly from an ASE database. Data can also be loaded from flat files as well as other data sources. See Module 8, "Loading Data from Files," Module 9, "Advanced Data Loading from Files" and Module 10, "Loading Data Using the INSERT Command." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview What Principles Are at Work? ■ Column-wise data structures ■ Bit-wise indexing This is an overview foil. These principles are covered in the next few pages. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 -1 3 Adaptive Server IQ Product Overview Column-Wise Data Structures Stores Data Column-Wise Rather Than Row-Wise ■ Vertical partitioning of data ■ Returns those columns necessary for a query, reducing I/O SELECT count(*) FROM customer WHERE gender = "M" Column-wise Column-wise data structures are easily searched without having to scan the full rows. Vertical partitioning of the data means never performing a table scan. At most, ASIQ would perform a column scan. Row-wise Row-wise data structures, such as those used in traditional RDBMSs, can be searched only by reading an entire page and then locating the data on the page. Because the columns being searched for are only a fraction of the total data read, there is excessive I/O. 1-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Bit-WiseIndexing Benefits Both Low- and High-Cardinality Columns ■ Translates the distinct data elements of a column into a bit mask ■ Cardinality - The number of unique values in a column • Low-cardinality data: Fewer than 1500 unique values • High-cardinality data: 1500 unique values or more ■ Example: High-Cardinality Data ■ Primary keys ■ Telephone numbers ■ Social security number Low-Cardinality Data ■ Day of week ■ Gender ■ States (continued . . .) Bit-wise indexing Unlike other indexing methods, ASIQ indexes are based on the cardinality of the data and the way the data will be used. ASIQ has indexes for both low- and high-cardinality columns. ASIQ indexing types are discussed in depth in Module 5, "ASIQ Index Types and Data Types". ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1-15 Adaptive Server IQ Product Overview Bit-WiseIndexing Low-Cardinality Example The table on the left shows the unindexed data The table on the right shows a bit-wise index (continued . . .) Note This is not an actual index. It is merely a representation of how bit-wise indexing works for low-cardinality data. This topic is discussed in detail in Module 5, "ASIQ Index Types and Data Types". 1-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Bit-Wise Indexing High-Cardinality Example Actual data in Binary Data is stored vertically High cardinality/ bit-wise indexing ©2000 Sybase, Inc. Sybase has patented technology for indexing high-cardinality data using bitmaps. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1-17 Adaptive Server IQ Product Overview ASIQ Multiplexing Allows a multi-server configuration Designed for managing large query loads across multiple nodes Supports many users, each executing complex queries against a shared database IQ Temp Store Catalog Store IQ Temp Catalog IQ Temp Catalog Store Store Store Store ASIQ Multiplexing IQ Main IQ Temp Catalog Store Store Store Must have ASIQ 12.4.2 or higher. Multiplexing is implements and managed through Sybase Central. ■ This topic is discussed in detail in Module 17, Multiplexing". “ 1-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Benefits of ASIQ ■ Reduced ongoing tuning of databases ■ Reduced need for Database Administrator resources after initial install ■ Reduced disk requirements ■ Rapid access to information ■ Users can access data with a variety of query tools ■ Indexes can be efficiently incrementally added or dropped • Without reloading data ■ ASIQ Version 12.4.2 can support a multi-server configuration, ASIQ Multiplex For more information about the benefits of ASIQ, see www. sybase. com/products/dataware/iqindex. html. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 -1 9 Adaptive Server IQ Product Overview Summary ASIQ Is... ■ Leading technology that stores data vertically ■ Fast at ad-hoc query resolution • Bit-wise storage solves low- and high-cardinality queries ■ Economical on disk usage due to compressed storage formats ■ Flexible, interoperable, open system ASIQ Is Not... ■ An OLTP database ■ For applications requiring real-time updates ■ A tool to tune an existing database 1 - 20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Adaptive Server IQ Product Overview Lab 1: ASIQ Product Overview Exercise Overview Topics ■ DSS . OLTP ■ High- and low-cardinality data ■ Row-wise and column-wise data structures ■ Bit-wise indexing Goal After completing this lab, you should be able to: ■ Explain the basic principles of ASIQ General tasks You will take a written quiz. Lab setup No lab setup is required. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1-21 2 Architecture and Terminology Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology Module Overview This module provides the necessary background information for performing installations and administration. Objectives After completing this module, you should be able to: ■ Describe the ASIQ architecture ■ Define ASIQ terminology and concepts ©2000 Sybase, Inc. 1 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2- Architecture and Terminology ASIQ Platforms ■ Sun Solaris (SPARC) ■ IBM RISC System/6000 AIX ■ HP-UX HP 9000/800 ■ Compaq UNIX ■ Windows NT ■ SGI IRIX ■ LINUX (coming soon) Refer to the Adaptive Server IQ Installation and Feature Guide for detailed information on each platform. Refer to the Adaptive Server IQ Release Bulletin for detailed information on product restrictions, operating system patches, new and changed features, and documentation errors. 2-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology Module Map ■ ASIQ Database Server ■ ASIQ Database • IQ Store • Catalog Store & Transaction Log • IQ Temporary Store • IQ Message Log ■ ASIQ Tables ■ ASIQ Indexes ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2-3 Architecture and Terminology Adaptive Server Anywhere and Adaptive Server IQ ■ Adaptive Server Anywhere (ASA) is a relational database system that can exist with or without IQ • Small memory footprint • ANSI SQL plus additional functionality • Proven database technology ■ Adaptive Server IQ (ASIQ) exists with ASA • Patented storage technology • Vertical data storage • High-performance database query engine Anywhere database An Adaptive Server Anywhere database. Anywhere tables Anywhere tables have a different format from IQ tables. Enterprise database An Adaptive Server Enterprise (ASE) database. Also known as a SQL Server store. T-SQL Transact-SQL is a superset of Structured Query Language (SQL). It includes all ANSI standard SQL plus additional commands. 2-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology Adaptive Server IQ Database Server ■ Combination of Adaptive Server Anywhere network server and ASIQ Server ■ ASA contains the catalog, language parser, and connectivity ■ IQ pieces include data store and query engine ASIQ ©2000 Sybase, Inc. Allows multiple users to query a database at the same time, while another user inserts or deletes data. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2-5 Architecture and Terminology ASIQ Server and Database (Wthout Multiplex) ■ Database specifically created to store ASIQ indexes ■ Includes the following components: • IQ Main Store (for data) • Catalog Store & Transaction Log (for metadata) • IQ Temporary Store (for temporary data) • IQ Message Log (for log file) ■ Has one database per ASIQ Server Components of an ASIQ database are discussed in detail in the following slides. ASIQ Multiplex has a similar component structure and is addressed later. 2-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology IQ Main Store ■ Contains the data (indexes) • Compressed in blocks on disk ■ First physical file name is dbname.iq • User specifies the name for additional files ■ One IQ Main Store per database • Can consist of many physical files • Can be raw or file system ■ Also contains an internally managed transaction log ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2-7 Architecture and Terminology Catalog Store ■ Contains information called metadata needed to manage an IQ database ■ Contains the system tables and stored procedures • Traditional horizontal storage system ■ Physical file names are: • dbname.db • dbname.log (Transaction Log) ■ One Catalog Store per database • Can consist of multiple devices (unusual) • File System ONLY (continued . . .) Metadata 2-8 ■ Describes the data in your database—for example, the size and datatype for each column in a table. ■ An ASA type datastore with 4K data pages. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology Catalog Store System Tables ■ In addition to the system tables, the Catalog Store contains ASIQ-specific system tables, for example: • SYSIQCOLUMN • SYSIQFILE • SYSIQINDEX • SYSIQINFO • SYSIQTABLE (continued . . .) SYSIQCOLUMN Lists information on columns in every table or view in the IQ store. SYSIQFILE Lists information on operating system files for the database. SYSIQINDEX Lists internal information on indexes in the database. SYSIQINFO Lists database characteristics in addition to those in the SYSINFO table. SYSIQTABLE Describes each table or view in the IQ Store. For a complete listing of system tables and views, see the Adaptive Server IQ Reference Guide. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 Architecture and Terminology Catalog Store Transaction Log ■ Only used to log changes to the Catalog Store (not the warehouse data) ■ Used to roll back (undo) or roll forward changes if necessary ■ Physical file name is dbname.log m Very small file (~ 15 to 20MB ) • Placement not an issue Default By default the dbname.log file is placed in the same directory as the .db file (but can be placed elsewhere). CREATE DATABASE command You can turn logging off using the CREATE DATABASE command, but this is not recommended. Pruning To prune this log, first stop the server and rename the dbname.log file, then restart the server. 2-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology IQ Temporary Store ■ Work area for the database • Sorting data during loads • Query processing work area ■ Physical file name is dbname. iqtmp ■ One IQ Temporary Store per IQ database • Can consist of several physical files • Can be raw or file system The IQ Temporary Store is used for both loads and queries. It is used to build HG indexes during loads. Queries use it to sort data during ORDER BY and join queries. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2-11 Architecture and Terminology IQ Message Log ■ Readable log file for the ASIQ database that contains: • Error messages • Status messages • Insert notification messages ■ Physical file name is dbname. iqmsg ■ One IQ Message Log per IQ database • File system only 2-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology Putting It All Together...ASIQ Database ASIQ Database Components (with No Multiplex) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2-13 Architecture and Terminology Module Map • ASIQ Database Server • ASIQ Database • IQ Store • Catalog Store & Transaction Log • IQ Temporary Store • IQ Message Log . ASIQ Tables ■ ASIQIndexes 2-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology ASIQ Tables ASIQ tables are logical tables defined in the Catalog Store • A table is really a group of columns Three types of tables: • Base tables • Local temporary tables • Global temporary tables These tables are discussed in great detail in Module 6, "Creating Tables and Indexes." Base tables These tables: ■ Are sometimes called main or permanent tables. ■ Are stored in the main IQ Store and are a permanent part of the database. ■ Must be dropped explicitly. Use the CREATE TABLE statement to create a base table. Local temporary tables Use the DECLARE LOCAL TEMPORARY TABLE statement. The table will exist until the connection ends or within a compound statement in which it is declared. This table is completely inaccessible to other users. Global temporary tables Use the GLOBAL TEMPORARY option of the CREATE TABLE statement. The table will exist in the database until it is explicitly removed. Each user will have a separate instance of the data in a global temporary table. Those rows are visible only to the connection that inserts them. They are deleted when the connection ends. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 2-15 Architecture and Terminology Utility Database ■ Created automatically during ASIQ installation ■ Used for connection purposes when no "real" database exists ■ Never holds data ■ DO NOT DELETE this database When to use the utility database 2 -16 To start the database server when no database is specified during the START ENGINE command. To create, drop, or restore a database when you have no other database to which to connect. To start the database server or connect to a database when other databases are corrupt or unavailable due to media failure. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology ASIQ Indexes ■ Each data column is assigned one or more data access methods (indexes) • Usually determined before initial load ■ Index type selection determined by: • Cardinality of data • Column usage ■ Four different types of indexes (discussed in Module 5): • Default Index (FP) • LF • HNG • HG Cardinality Low - Fewer than 1500 unique values. High - 1500 or more unique values. Column usage Joins, GROUP BY, aggregation. Index types are discussed in further detail in Module 5, "ASIQ Index Types and Data Types." ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2-17 Architecture and Terminology ASIQ Tables and ASIQ Indexes Tables Contain Indexes on Columns ■ An index is an access method ■ Each ASIQ index contains all the data for a column ■ A column has one or more indexes ■ A default index is placed on each column when the table is created 2-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology interfaces File and ASIQ Connectivity ■ TDS clients and servers find each other via lookups in an interfaces file ■ The interfaces file is required for: • Servers, to discover the net addresses they should listen to for client connections • Clients, to discover where to direct connection requests ■ The interfaces file has different names on different platforms: • UNIX: $SYBASEinterfaces • Windows: %SYBASE%\ini\sql.ini • Novell Netware (clients only): interfac ■ TDS clients and CIS servers use the interfaces file to find an ASIQ Server instance ASIQ ©2000 Sybase, Inc. ASIQ uses the command line during startup and not the interfaces file. TDS clients (for example, SQL Advantage) will need the interfaces file, but DBISQL and Sybase Central do not. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2-19 Architecture and Terminology ASIQ Architecture Putting It All Together... 2-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Architecture and Terminology Summary ■ An ASIQ database contains: • IQ Main Store (contains the data) • Catalog Store & Transaction Log (contains metadata) • IQ Temporary Store (contains temporary data) • IQ Message Log (contains database log file) ■ The ASIQ table definition is stored in the Catalog Store ■ The data is stored in indexes in the IQ Main Store ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2-21 Architecture and Terminology Lab 2: Architecture Exercise Overview Topics ■ ■ ■ Goals After completing this lab, you should be able to: ■ Define ASIQ architecture and terminology General tasks Lab setup 2-22 Process architecture components and functions ASIQ architecture Terminology: • ASIQ database server • ASIQ database • IQ Store • Catalog Store & Transaction Log • IQ Temporary Store • IQ Message Log • ASIQ tables • ASIQ indexes ■ Complete a matching game. ■ Complete a multiple-choice quiz. ■ Complete fill-in-the-blank questions. ■ Participate in an instructor-led discussion. ■ No lab setup is needed. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 3 ASIQ Environment and Installation Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Module Overview This module provides the necessary background information to install ASIQ and to connect to ASIQ. Objectives After completing this module, you should be able to: ■ Prepare for an ASIQ installation ■ Install ASIQ ■ Verify the success of an ASIQ installation This module is divided into two sections: ■ Environment & Installation. ■ Connectivity. ©2000 Sybase, Inc. 1 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3- ASIQ Environment and Installation Module Map ■ System Requirements • Disk space • Memory • Swap ■ Installing ASIQ ■ Validating ASIQ Installation ■ Setting Up ODBC ■ Setting Up JDBC and Open Client 3-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Disk Space ■ IQ binaries • UNIX: ~300MB (if all binaries are installed) • NT: ~120MB ■ Database size • IQ Main Store: 70 - 100% of raw data • IQ Temporary Store - Varies based on users and data ■ Data staging area • Space required to load raw data from file ■ Swap • 2-3 times the amount of physical memory (RAM) The IQ binary size will vary from platform to platform. Refer to the Adaptive Server IQ Installation and Feature Guide for a specific platform. Database size The size of the IQ Main Store depends on the types of IQ indexes used and the data itself. Staging area If you are loading from another server, you do not need this additional space. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-3 ASIQ Environment and Installation Virtual Memory Virtual = Physical Memory + Swap Disk Space ■ Recommended minimum of 512MB of RAM ■ When the system is out of physical memory, swapping occurs • Processes are copied (swapped) out of memory to disk • Inactive pages are written from memory (paged) to disk ■ ASIQ has its own buffering system • Decides how to page buffers in and out of memory • Uses the operating system's swap disk ■ ■ Sybase recommends 256MB of RAM dedicated to ASIQ. 512MB allows for the operating system and other necessary components. More is better As with any RDBMS software, ASIQ requires a lot of memory. The more memory you can allocate to ASIQ, the better your system performance will be. Paging and swapping There is always a fixed limit to the amount of memory in a system. As a result, operating systems sometimes can have only part of the data in memory and the rest on disk. Paging or swapping occurs when the operating system must go out to disk and retrieve any data before a memory request can be satisfied. The primary objective of good memory management is to avoid or minimize paging or swapping. VMSTATorSAR Use the UNIX VMSTAT command or the SAR command, if available, to get statistics on the number of running processes and the number of page-outs and swaps. Use this information to find out whether the system is paging excessively, then make any necessary adjustments. Try to put your swap files on special fast disks. For more information on VMSTAT, type MAN VMSTAT. 3-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Swap Also Known As Swap Disk or Swap Partition ■ Recommendation: Swap should be set between 2-3 times the physical memory ■ See specific operating system information about extending swap ■ ASIQ uses shared memory for reads and writes • ASIQ pages out buffers to the swap disk ■ Insufficient swap space may result in: • System supporting fewer users • A large process may be stopped for lack of virtual memory Swap files ■ ■ ■ Examining swap The most frequently used operating system files are swap files. When memory is exhausted, the operating system swaps pages of memory to disk to make room for new data. When the pages that were swapped are called again, other pages are swapped, and the required memory pages are brought back. This is very time-consuming for users with high disk-usage rates. In general, organize memory to avoid swapping and thus minimize use of operating system files. On HP-UX: as root, type /etc/swapinfo On Solaris:/usr/sbin/swap -s On Compaq: as root, type /sbin/swapon -s On NT: Control Panel->System->Performance ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-5 ASIQ Environment and Installation Basic Configuration Recommendations System Requirement Recommendation Disk Space IQ binaries (~120- ~300MB) + database size (70-100% raw data) + staging area + IQ temporary space + swap (2-3 times RAM) RAM Recommend 512MB (more is better) ■ ■ IQ temporary space 3-6 The IQ binary size number can vary from platform to platform. Check the Adaptive Server IQ Installation and Feature Guide for a particular platform. Default is set to 50% of database size. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Hardware Recommendations Number and Type of Processors ■ More is better • Faster loading with SMP • Better multiuser performance ■ Faster is better • 233 MHz (or more) • IQ is more CPU intensive than I/O intensive CPU intensive ©2000 Sybase, Inc. The reason ASIQ is more CPU intensive is because of compressing and decompressing data. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-7 ASIQ Environment and Installation Module Map • System Requirements . Installing ASIQ • UNIX install • NT install ■ Validating ASIQ Installation ■ Setting Up ODBC ■ Setting Up JDBC and Open Client 3-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Before Installing Software on UNIX ■ Decide what components to install • ASIQ Server will likely be installed ■ Optional Components • Sybase Open Client Libraries ▲ Only need if you will load data from another Sybase server or if you want to use the ISQL client A Version 11 or Version 12, not both A Should install Open Client 12 unless Sybase ASE 11.x server is running on the same UNIX server ■ Sybase Central on the UNIX server • You need Sybase Central only if you want to run it on the UNIX server • May be installed on a Windows 9598/Win NT client ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-9 ASIQ Environment and Installation Preparing for ASIQ Installation on the UNIX Platform Before You Begin 1. Check for proper version of the OS 2. Install kernel patches (if any) 3. Set kernel parameters to suggested values 4. Configure user resource limits with ULIMIT -A, then reboot 5. Verify network functionality with TELNET host For more information on the individual platforms, see Chapter 1, "Adjusting the Operating System Configuration," in the Adaptive Server IQ Installation and Configuration Guide. 3-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Installing Adaptive Server IQ UNIX 1. Set the environment variable $SYBASE to a file system for the ASIQ binaries 2. Create the user "sybase"; home for the user "sybase" is $S YBASE 3. Mount the CD-ROM drive 4. Start the install utility, SYBINSTALL 5. Follow options on SYBINSTALL screen • Accept the default username and password for the utility database • After installation, you need to set additional environment variables Mounting CD-ROM drive Check the Adaptive Server IQ Installation and Feature Guide for the exact commands for your platform. If you have an existing version of Open Client on your system, installing the Open Client libraries will add missing Open Client files and overwrite older files. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-11 ASIQ Environment and Installation Setting Environment Variables ■ $SYBASE • Set to the /sybase directory (should already be set) • Contains up to three subdirectories A asiq_12 A sybase-central_3.2 (optional) A ociq-11_0(optional) or ociq-12_0(optional) Open Client 3-12 ■ ■ Open Client 11 - ociq-11_0 Open Client 12 - ociq-12_0 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Setting Environment Variables ■ $ASDIR • $ASDIR = $SYBASE/asiq_12 • This directory contains the ASIQ Server binaries bin/ charsets/ include java/ javaconnect/ lib res/ scripts tix/ m $LD_LIBRARY_PATH • $LD_LIBRARY_PATH = $ASDIR/lib • This directory contains critical ASIQ Server library files (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-13 ASIQ Environment and Installation Setting Environment Variables ■ $SYBASE_OCS • Required only if you install Open Client 12 • $SYBASE_OCS = $SYBASE/ociq-12_0 ■ $PATH • Modify your path to include the following: A $ASDIRbin ♦ This is for the ASIQ Server binaries A If Open Client 11 is installed: ♦ $SYBASEbin A If Open Client 12 is installed: ♦ $SYBASE_OCS/bin ■ $ASLOGDIR (optional) • Specify a directory for ASIQ Server log messages • A new log message file will be created each time the server is started 3-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Starting the ASIQ Server - UNIX ■ ASIQ Server must be started with a database ■ After installation, you must start the ASIQ Server with either the asiqdemo database or the utility database ■ asiqdemo database • Supplied with the software • Easiest way to start and test the server installation ■ utility database • Never holds data ■ A "database" is a database file with a .db extension • Example: asiqdemo.db The ASIQ Server must be started from a writable directory. The directory where the server is started becomes the default directory for all files created by the ASIQ Server. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-15 ASIQ Environment and Installation Starting the ASIQ Server - Simple Method ■ Syntax: start_asiq dbname ■ start_asiq is located in $ASDIR/bin ■ Starts the server as a background process ■ Example: % start_asiq asiqdemo.db ■ This example starts the server with the asiqdemo database, this example assumes you are in the $ASDIR/demo directory ■ The default start parameters will be used 3-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Starting the ASIQ Server - UNIX ■ Preferred method of starting the server in UNIX ■ Syntax: start_asiq @configuration_file.cfg dbname m Example: % start_asiq @$ASDIR/demo/asiqdemo.cfg $ASDIR/demo/ asiqdemo.db ■ This example starts the server with the asiqdemo database ■ The configuration file is used to specify options you want whenever you start your server ©2000 Sybase, Inc. Administering Adaptive Server IQforthe DataWarehouse, Version 1.0 3-17 ASIQ Environment and Installation Server Configuration File All Platforms ■ A file with a .cfg extension that contains server starting parameters ■ These parameters override default ASA engine starting parameters ■ Are critical parameters for ASIQ performance ■ Configuration file example: -n eptgdev2_asiqdemo -c 16m -gd all -gm 10 -gp 4 0 96 -x tcpip{port=2638} ■ Do not use commas to separate parameters in this file Additional parameters are required to use Sybase Open Client. Discussed in "Connectivity" module. Example: asiqdemo.cfg -n eptgdev2_asiqdemo Server name (machine name_dbname) -c 16m Catalog Store cache size -gd all Database starting permissions -gm 10 Number of connections (default is 10) -gp 4096 Catalog Store page size -x tcpip{port=2638} Network connection protocol; 2638 is the default port number 3 -18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Stopping the Server UNIX ■ Run the STOP utility • stop_asiq A This utility prompts the user to stop an ASIQ Server • dbstop A Requires connection parameters ■ Example: dbstop -c "uid=DBA;pwd=SQL;eng=eptgdev2;dbn=asiqdemo" ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-19 ASIQ Environment and Installation Preparing for ASIQ nstallation on the NT Platform Before You Begin 1. Check the OS • See the ASIQ Release Bulletin for latest OS release information • Special instructions apply to NT Enterprise servers using more than 2 GB of memory 2. Decide what components to install • ASIQ Server will probably be installed • Optional components A Sybase Open Client Libraries - Version 11 or Version 12 • Sybase Central on the NT server 3. Check for sufficient page file (swap) space • You will reboot ASIQ after software is installed 4. Decide on location for binaries • Approx. 110MB required for ASIQ Server binaries • Approx. 24MB for Open Client (optional) • Approx. 35MB for Sybase Central Java Edition (optional) 3-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Installing ASIQ Server Components Required for Operation As a Network Server 1. Log in using an account with Administrator privileges 2. Exit any Windows programs running on your machine 3. Insert CD-ROM into CD-ROM drive 4. Run setup.exe 5. Select products to be installed • ASIQ Server ▲ Click Change button to view subcomponents A Deselect unnecessary subcomponents (as desired) ♦ 16-bit ODBC drivers ♦ C++ development components • Sybase Central Java Edition • Open Client 6. Accept the default login (DBA) and password (SQL) for the utility database (can be changed later) 7. Click Finish to complete installation 8. Restart computer If you have an existing version of Open Client on your system, installing the Open Client libraries will add missing Open Client files and overwrite older files. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-21 ASIQ Environment and Installation Starting the Server Start ASIQ ■ Click Start on the taskbar, select Programs-> Sybase->Adaptive Server IQ 12->Start ASIQ Demo Database • Starts the asiqdemo database using the name of the server on which you are running ASIQ or ■ At the NT command prompt: asiqsrv12 @asiqdemo.cfg asiqdemo.db ■ This example assumes you are in the $ASDIR/demo directory See the UNIX example in the student notes for contents of asiqdemo.cfg file. To display the startup options available, enter the following at the NT command prompt: asiqsrv12 /? ASIQ Server must be started with a database, either the asiqdemo or utility database. After creating a database, you can start the server with that database. 3-22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Stopping the Server Stop ASIQ - NT 1. Double-click the icon in the Windows system tray to display the server window 2. Click Shutdown ■ Command-line options during startup control whether a server is stopped even if there are active connections ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-23 ASIQ Environment and Installation Installing ASIQ Server Client Components Required for Connection to a Network Server 1. Log in using an account with Administrator privileges 2. Exit any Windows programs running on your machine 3. Insert Client Components CD-ROM into CD-ROM drive 4. Run setup.exe 5. Select products to be installed • ASIQ 12 client components A Decide which subcomponents to install (click Change) ♦ 16-bit ODBC drivers may not be needed ♦ C++ development components (if needed) • Sybase Central Java Edition (for DBA) • Open Client 12 (if needed) A Open Client used in this class A Not required at some sites 6. Click Finish to complete installation 7. Restart computer Sybase Central and ASIQ are installed in separate folders unless you specify otherwise. 3-24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Module Map • System Requirements • Installing ASIQ ■ Validating ASIQ Installation ■ Setting Up ODBC ■ Setting Up JDBC and Open Client ©2000 Sybase, Inc. 25 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3- ASIQ Environment and Installation Validating the ASIQ Environment Was the Installation Successful? ■ Examine the installation log files ■ Access the ASIQ Server using: • DBISQL • Sybase Central (for database administration) • ISQL • Third-party tools ■ First, set up ODBC and JDBC • Next section 3-26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Lab 3-1: Installation Exercise Overview Topics ■ Goals After completing this lab, you should be able to: . Install ASIQ ■ Start the ASIQ Server using the sample database General tasks ■ Increase virtual memory on your machine ■ Install the ASIQ Server components ■ Start the ASIQ Server ■ Define and document the ASIQ environment Lab setup ■ ■ ©2000 Sybase, Inc. 27 Installing ASIQ Server components Sufficient disk space and shared memory must be available. Must have the following CD: • Sybase Adaptive Server IQ for Microsoft Windows NT 4.0, version 12.0 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3- ASIQ Environment and Installation Module Map • System Requirements • Installing ASIQ • Validating ASIQ Installation . Setting Up ODBC • Connect using DBISQL (GUI) • Connect using DBISQL (Quite Mode) • Connect using Sybase Central ■ Setting Up JDBC and Open Client 3-28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Setting Up ODBC Start the ODBC Administrator • Start->Programs->Sybase->Adaptive Server IQ 12->ODBC Administrator Create a DSN (Data Source Name) by clicking Add (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-29 ASIQ Environment and Installation Setting Up ODBC Add a New Source ■ Select the Adaptive Server IQ 12 Driver Click Finish (continued . . .) 3-30 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Setting Up ODBC Name the Data Source (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-31 ASIQ Environment and Installation Setting Up ODBC Log In ■ Click the Login tab ■ Enter a user ID of DBA and a password of SQL (continued . . .) 3-32 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Setting Up ODBC Database Tab ■ Click the Database tab ■ Enter the database name of asiqdemo ■ Enter the full path for the asiqdemo.db (Catalog Store) file • Click Browse, if desired Can specify server name and server start command file May want to uncheck the Auto start and Auto shut down (continued ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-33 ASIQ Environment and Installation Setting Up ODBC Network Tab ■ Click the Network tab ■ Click TCP/IP ■ For remote servers; identify the host and port • Examples: host=poobah:2345 host=157.133.75.36:2345 (continued . . .) 3-34 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Setting Up ODBC Test the Connection ■ Click the ODBC tab ■ Click the Test Connection button ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-35 ASIQ Environment and Installation Connection to ASIQ using DBISQL Interactive SQL ■ DBISQL is an ODBC Client for communicating with ASIQ • Comes with the software • Preferred method for communicating with ASIQ • Useful for database administration • Can be used as a simple query tool ■ DBISQL has two modes • GUI • Quiet Mode (no GUI) 3-36 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Starting DBISQL - GUI ■ Windows: • Start->Programs->Sybase->ASIQ 12->Interactive SQL ■ UNIX: % dbisql -c "uid=DBA;pwd=SQL;eng=eptgdev2_asiqdemo" Option Description "" Need to use double quotes -c Database connection parameters uid User id pwd Password eng Servername ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-37 ASIQ Environment and Installation Ready to Connect Interactive SQL ■ Start->Programs->Sybase->ASIQ 12->Interactive SQL ■ Specify the ODBC DSN you just created 3-38 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Interactive SQL ■ Enter commands in the bottom window ■ Function keys • F1 = Help for DBISQL • F7 = List tables (select table to list the columns) • F9 = Execute command (or click the Execute button) • F10 = Activate menus at top of window ■ Stop = Cancel command ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-39 ASIQ Environment and Installation Connect Using Command Line DBISQL DBISQL (Quiet mode) ■ Syntax: dbisql ‘ -c keyword=value; . . . ' ] [-d] [-q] [-x] Option Description -d Command delimiter (defaut is ;) -q Quiet mode (no window or messages), used to submit scripts -x Syntax check only ■ Example: dbisql -c ‘uid=DBA;pwd=SQL;eng=eptgdev2_asiqdemo' -q load.sql ■ In this example load.sql is the name of the script file Parameters ■ ■ Always embedded in quotes. Separated by a semicolon. See Chapter 2 of the Adaptive Server IQ Administration Guide or Chapter 3 of the Adaptive Server IQ Reference Manual. 3-40 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Connecting Through Sybase Central ■ Graphical user interface to Sybase database products • Can use ODBC or JDBC to connect • This is a Java version of Sybase Central for use only with ASIQ To connect to ASIQ (NT): 1. Open the Adaptive Server IQ 12 folder • Click Start on the taskbar, select Programs->Sybase-> ASIQ12->Sybase Central 2. Enter a login and password in the connection dialog box To connect to ASIQ (UNIX): % cd $SYBASE/sybcentral % scjview ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-41 ASIQ Environment and Installation Sybase Central Connecting to a Database ■ On the Sybase Central menu bar, select Tools->Connect->ASIQ ■ In the connection box, click ODBC and enter the data source name 3-42 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Sybase Central Features ■ Create an IQ database ■ Add or remove database devices ■ Create tables, views, and indexes ■ Create stored procedures ■ Add users and groups and manage permissions ©2000 Sybase, Inc. 43 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3- ASIQ Environment and Installation Module Map • System Requirements • Installing ASIQ • Validating ASIQ Installation • Setting Up ODBC ■ Setting Up JDBC and Open Client 3-44 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Database Configuration File for Open Client 12 ■ This step is required only if you access an ASIQ 12 with Open Client 12 ■ Add a parameter in the server configuration for the database name ■ Use a second -n parameter for the database name ■ This database name is used in the interfaces file as the server name ■ Example: -n eptgdev2_asiqdemo -c 16m - g d a l l -gm 10 -gp 4 0 96 -n asiqdemo ■ See the ASIQ Release Bulletin on Open Client Library changes ©2000 Sybase, Inc. 45 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3- ASIQ Environment and Installation Setting Up JDBC and Open Client ■ Set up a server entry using DSEDIT • Start->Programs->Sybase->Open Client Directory Services Editor • Click OK (continued . . .) 3-46 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Setting Up JDBC and Open Client Under Server Object, click Add (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-47 ASIQ Environment and Installation Setting Up JDBC and Open Client ■ Enter the server name Enter the network address for the server (continued . . .) 3-48 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Setting Up JDBC ■ Dsedit should look similar to this: You can ping the server to test the connection you made ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-49 ASIQ Environment and Installation Connect Using ISQL ■ Start ISQL from command window ■ Example: isql -UDBA -PSQL -Sasiqdemo [-i<file>][-o<file>] ■ You are connected to your database • No concept of USE DATABASE • Command terminator default is still "go" 3-50 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation ISQL Versus DBISQL ■ You cannot direct output from DBISQL • No equivalent to ISQL -o parameter • IQ has TEMP_EXTRACT options for SELECT ■ DBISQL command terminator is a semicolon (;) ■ DBISQL can start the server, if desired ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-51 ASIQ Environment and Installation sp_iqstatus Shows information about the current database • Database name • Creation date • IQ Page size • Block size IQ-specific stored procedure, which is valid only on ASIQ servers If you are unable to connect and execute a command, check the "Troubleshooting" section of the Adaptive Server IQ Administration Guide. IQ Page size Adaptive Server IQ displays the IQ Page size in addition to the block size. For example: Page Size: 1024/512blksz/2bpc 3-52 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Running sp_iqstatus Command to Check ASIQ ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3-53 ASIQ Environment and Installation Summary of Installation Steps ■ Prepare for the ASIQ install • Disk space • RAM ■ Perform the installation • Follow steps outlined and use installation guide ■ Verify the installation • DBISQL • Sybase Central (for database administration) • ISQL ■ Run sp_iqstatus to show database information For more information on the individual platform installations, see the appropriate Adaptive Server IQ Installation and Feature Guide. 3-54 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Environment and Installation Lab 3-2: Connectivity Exercise Overview Topics ■ ■ ■ Goals After completing this lab, you should be able to: ■ Set up a DSN using the ODBC Administrator ■ Use DSEDIT set up JDBC ■ Connect to the server using Interactive SQL General tasks ■ ■ ■ Access the asiqdemo database using Interactive SQL and ODBC. Run sp_iqstatus to list information about the asiqdemo database. Install student files for later use. Lab setup ■ Must have installed the ASIQ Server in Lab 3-1. ©2000 Sybase, Inc. 55 How to use the ODBC Administrator Setting up a server entry using DSEDIT Connecting to the server using Interactive SQL Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 3- 4 Creating Databases Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Creating Databases Module Overview This module describes how to create and administer an ASIQ database. Objectives After completing this module, you should be able to: ■ Determine space requirements for a database ■ Create/drop a database ■ Add space to a database ■ Drop space from a database ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-1 Creating Databases Database Review ■ Created using CREATE DATABASE command IQ database Consists of the IQ Store, the Catalog Store, the Transaction Log, the IQ Temporary Store, and the IQ Message Log File containing related information. IQ Store Catalog Contains the IQ data as well as the database transaction log. Store Transaction Contains table definitions, system tables, and stored procedures. Log IQ Temporary Contains the updates to the metadata. Contains temporary tables Store IQ Message generated by certain queries. Log File Contains error, status, and insert notification messages for the IQ database. 4-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Database Overview dbspace ■ A dbspace is a logical name for a database device ■ Each database includes multiple dbspaces ■ The IQ Store, Catalog Store, Transaction Log, IQ Temporary Store, and IQ Message Log File all consist of dbspaces ■ Initially, each IQ Store has only one dbspace ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-3 Creating Databases Creating a Database 1. Select the device type 2. Estimate the database size 3. Create the database Step 1 Either raw or file. Step 2 Need to know the size of the raw data to be loaded. Step 3 This step is similar to using the DISK INIT and CREATE DATABASE commands on ASE. 4-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Step 1: Select the Device Type Raw Partitions Versus File Systems Advantages Raw Disadvantages - Managed by application, not the - Harder to manage file system - Performance can be higher - Avoid UNIX file system overhead - ASIQ has buffer control File System - Manageability - Additional overhead for reads - Double buffering - File system does not understand ASIQ pages Raw partitions Raw partitions are recommended for production environments because they do not use memory for file system buffering. File Systems ■ ■ set ■ ©2000 Sybase, Inc. If you are using file systems for your IQ database and running on Solaris or NT, you should consider turning off file system cache buffering. Some queries are competing within the OS for cache. To disable buffering: option public.OS_File_Cache_Buffering='Off You then need to cycle the ASIQ server. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-5 Creating Databases Step 2: Estimate the Database Size ■ Use 100% of the size of the raw data for the IQ Store • Additional space can always be added ■ The proper sizing of the IQ Temporary Store depends on: • Number of users • Loading of HG indexes • Types of queries ■ The IQ Temporary Store is 50% of the IQ Store by default ■ Question to ask • What is a good dbspace size? dbspace size 4-6 Recommendations are specific for each platform. Check the specific platform guide. dbspace sizing is also discussed in Module 15, "Performance & Tuning." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Step 3: Create the Database ■ Can either use CREATE DATABASE statement in DBISQL or use Sybase Central ■ Must have the server started with an existing database (asiqdemo or utility) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-7 Creating Databases Files Allocated When Creating Database ■ dbspaces created with CREATE DATABASE • dbname.iq - Main IQ Store • dbname.db - IQ Catalog Store • dbname.log - Transaction Log • dbname. iqtmp - IQ Temporary Store • dbname.iqmsg -Message Log dbname.iq You can specify a different name during database creation. You can add dbspaces to increase the size of the main IQ Store. dbname.db This is the initial dbspace for the Catalog Store; you can later add dbspaces to increase the size. dbname.log This is the dbspace for the Catalog Transaction Log; by default placed in the same directory as the .db file. dbname.iqtmp The required size can vary depending on query types and the amount of data. You can later add dbspaces to increase its size. dbname.iqmsg You can specify a different file name on database creation. In addition to these database files, the database server also uses a temporary file to hold information during a session. This file is not the same as the IQ Temporary Store. 4-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Full Syntax Required ■ The IQ PATH clause is required for creating an IQ database. Otherwise, you will create a standard Adaptive Server Anywhere database. Defaults: Relative Pathnames ■ The Catalog Store and the IQ Store are created relative to the working directory of the ASIQ Server. The Temporary Store and the Message Log are created in the same directory as the Catalog Store. ■ Creating a database with relative pathnames can cause unexpected results. It is better to create a database using fully qualified pathnames. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 Creating Databases Command Options ■ db-name • Usually databasename.db • For example: mydb.db m LOG OFF • Recommendation: do not use ■ TRANSACTION LOG clause • By default, log placed in the same directory as the .db device ■ MIRROR clause • By default, no transaction log mirror ■ CASE clause • By default, case sensitive (CASE RESPECT) (continued . . .) db-name ■ This is the full path for the Catalog Store file. TRANSACTION LOG ■ The database server tracks all changes made by all users in this log. It should be placed on a different physical device from the .db and .iq dbspaces. MIRROR ■ This is an identical copy of the transaction log. You must provide a pathname, usually on a separate device to mirror. CASE ■ Used during comparisons and string operations. 4 -10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Command Options ■ PAGE SIZE clause • By default, 4096 (PAGE SIZE 4K) • Recommend leaving at default ■ COLLATION clause • By default, collation of uppercase and lowercase letters is identical for a case-sensitive database ■ BLANK PADDING clause • By default, trailing blanks are ignored (ON) ■ JAVA clause • By default, installed (JAVA ON) (continued . . .) PAGE SIZE ■ This is the page size for the catalog tables. It can be 1024, 2048, or 4096 bytes. Using 4096 is recommended, because each server can support only one catalog page size. By setting this value high, you will always have an adequate page size for the Catalog Store. COLLATION ■ If data is all one case, use ISO_BINENG. If mixed-case data, use the default. BLANK PADDING ■ Should be set to ON to ignore trailing blanks in queries. JAVA ■ To use Java in your database, you must install entries for the Sybase runtime. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-11 Creating Databases Command Options ■ JCONNECT clause • By default, ON (JCONNECT ON) ■ IQ PATH • Required; should be an absolute file path ■ IQ SIZE • For raw, by default, use the entire raw device • For file, no default; you must specify a size in MB ■ IQ PAGE SIZE • By default, 65536 (64K) • For low-memory and high-user-count systems, use 32,768 (32K) • For Very Large Data Base (VLDB) systems (greater than 50GB), use 131,072 (128K) (continued . . .) JCONNECT ■ To use the jConnect JDBC driver, you need to install jConnect support. IQ PATH ■ The pathname where the IQ data will be stored. It can be a file or raw partition. IQ automatically detects which type is specified. There is a limit of 65536 devices. IQ SIZE ■ The size in MB of the file you specified with the IQ PATH clause. For raw partitions, you should always accept the default, which is not to specify size. For file, you can specify a value up to 128GB, depending on the operating system. IQ PAGE SIZE ■ The page size in bytes for the IQ Store. This value is a power of 2 between 1K and 128K. The IQ PAGE SIZE determines the default I/O transfer block size and maximum compression. Recommendations: • Low memory (<512MB) with more than 5 users and/or large database, use 32K. • Generally use the default. • For databases larger than 50GB, use 128K. ■ 4-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Command Options ■ BLOCK SIZE • Default is system generated by IQ Page Size • The default is virtually always optimal ■ MESSAGE PATH • By default, created relative to the directory of the .db file ■ TEMPORARY PATH • By default, created relative to the directory of the .db file • Recommend specifying a path ■ TEMPORARY SIZE • By default, one half the size of the value of IQ SIZE for files • Recommend specifying a size BLOCK SIZE ■ ■ ■ ■ The I/O transfer block size for the IQ Store. Valid values are between 512 and 32,768. For the default IQ Page Size of 64K, the Block Size default is 4096. See Module 7, "ASIQ Memory Configuration," for the table of default block sizes. Recommendation: Do not touch! MESSAGE PATH ■ ■ The pathname where the IQ message files will be stored. Can be a raw partition or file. IQ automatically detects which type. A file system is recommended. TEMPORARY PATH ■ The pathname of the temporary file containing temporary tables generated by certain queries. Can be raw partition or file. Raw device is recommended. ■ TEMPORARY SIZE ■ ■ ©2000 Sybase, Inc. The size in MB of either the raw partition or the operating system file you specified with the TEMPORARY PATH. For raw partitions, you should always accept the default, which is to use the entire raw partition. The default for file is one half the value of IQ SIZE. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-13 Creating Databases Create Database: Example 1 ■ NT example: CREATE DATABASE 'D:\\mydb\\mydb.db' BLANK PADDING OFF IQ PATH 'D:\\mydb\\mydb.iq' IQ SIZE 200 PAGE SIZE 4096 ■ Creates an IQ database called mydb with the following files all in the same directory: • mydb.db - mydb.iqtmp - mydb. log • mydb. iq - mydb. iqmsg m All files are created in d:\mydb ■ The size of the database is 200MB with a page size of 4K Example In NT, if you specify a path, any backslash characters must be doubled if they are followed by an "n" or an "x". This prevents them from being interpreted as a newline character or as a hexadecimal number. It is always safer to double the backslash. Specifying all the options and not relying on the defaults is a good idea. 4-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Create Database: Example 2 ■ UNIX raw partition example: CREATE DATABASE big.db IQ PATH '/dev/md/rdsk/big.iq' MESSAGE PATH '/sq/data/big.iqmsg' TEMPORARY PATH '/dev/md/rdsk/big.iqtmp' PAGE SIZE 4096 ■ Raw devices for: • IQ PATH • TEMPORARY PATH ■ How big will the IQ Main Store and IQ Temporary Store be? The IQ Main Store and IQ Temporary Store will be as big as the raw device has been defined. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-15 Creating Databases Creating Databases: Sybase Central (continued . . .) Sybase Central Open the Utilities folder and select Create Database. ■ Follow the create database wizard and select desired database options. • You need to select a file name for the new database, such as mydb.db. • Also, you can select the options listed in the create database command. Create Database wizard ■ 4-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Creating Databases: Sybase Central This is the last page of the wizard. The lab guides you through each step in the Create Database wizard. Caution: Clicking the Back button resets Sybase Central to the default values for creating a database. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-17 Creating Databases Before Starting the Server with the New Database ■ Create a configuration file for the new database • Specify database name • Specify port number • Specify any other startup options desired • Each option must be on its own line ■ Example: mydb.cfg -n eptgdev2_mydb -c 16m -gc 6000 gd all -gm 10 -gp 4 0 96 -gr 6000 -ti 4400 -tl 300 -x tcpip{port=2640 Definition of the command-line switches are coming. 4-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Command-Line Switches Server switches that are needed to run ASIQ effectively ■ -n = server name • Required if server is started without a database ■ -c = cache size for Catalog Store • Default = 2 MB • Recommend 16MB to keep entire catalog in cache ■ -gp = Catalog store page size • Default = 1024 • Recommend 4096 to allow more table columns ■ -gm = limits number of concurrent users • Default = 10 • Recommend to set as needed, up to maximum in license ©2000 Sybase, Inc. Administering Adaptive Server IQforthe Data Warehouse, Version 1.0 4-19 Creating Databases Other Recommended Switches ■ -gc = checkpoint interval (minutes) • Default = 60, recommend 6000 ■ -gr = max recovery time interval (minutes) • Default = 2, recommend 6000 ■ -ti = default client timeout (minutes) • Interval to disconnect inactive clients • Default = 240, recommend 4400 (~73 hours) ■ -tl = default network timeout (seconds) • Interval a "liveness" packet is sent to a client • Default = 120, recommend 300 or higher 4-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Command-Line or Configuration File Switches Server switches that override the SET OPTION command ■ These parameters can be on the command line or in the configuration file • -iqmc = main cache size A Specify main cache size in MB ▲ Overrides MB values of the database options • -iqtc = temporary cache size A Specify main cache size in MB ▲ Overrides MB values of the database options ■ Example (command line): %asiqsrv12 50 @asiqdemo.cfg asiqdemo.db -iqmc 50 -iqtc These switches are useful to start the database if memory has been overallocated and the database will no longer start. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-21 Creating Databases Communication Protocols ■ Server starts up with all available protocols • Default behavior ■ TCP/IP supported on all platforms ■ WinNT platforms • IPX - Client and server (and Win95 clients) • NetBIOS - Client and server (and Win95 clients) • Named pipes (for Win 3.x clients using ODBC) 4-22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Communication Protocol Switches ■ Use the -x parameter to specify protocols • Default TCP/IP port will be 2638, if not specified ■ Examples: -x tcpip(MyIP=192.75.2 0 9 . 1 2 : 2 3 6 7 ) A Equates to an IP address with port 2367 -x tcpip A Use only TCP/IP with default port -x tcpip(port=2640) A Start server using port 2640 ©2000 Sybase, Inc. 23 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4- Creating Databases Starting the Server with the New Database ■ Start server from command line ■ Assume in the appropriate directory ■ NT example: asiqsrv12.exe @megaphone.cfg megaphone.db ■ UNIX example: asiqsrv12 @megaphone.cfg megaphone.db 4-24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Creating a New DSN Set up ODBC See the section "Setting Up ODBC" in Module 3, "ASIQ Environment and Installation," for more information ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-25 Creating Databases Viewing the New Database: Sybase Central Sybase Central To connect: Tools->Connect->Adaptive Server IQ. Specify the user ID and password with the DSN name or use JDBC and specify the correct port number. Example The database created is called mydb. The server is eptgdev2. Double-click eptgdev2_mydb to see a statistics folder and mydb (DBA) database. 4-26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases sp_iqstatus ■ Provides detailed information about the current database ■ Includes percentages of the IQ Store and IQ Temporary Store used ■ Can use Interactive SQL or DBISQL ■ Example on next page ©2000 Sybase, Inc. 27 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4- Creating Databases Checking the Database with sp_iqstatus ■ sp_iqstatus: 4-28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Enlarging a Database ■ Syntax: CREATE DBSPACE dbspace -name AS filenam e ... [ { IQ STORE | IQ TEMPORARY STORE | CATALOG STORE } . . . [ [SIZE] file-size ] ■ Example: CREATE DBSPACE mydb_tmp_2 AS 'e:\\s2\data\\mydb_2.iqtmp' IQ TEMPORARY STORE SIZE 200 ■ Creates an additional dbspace for the IQ Temporary Store ■ When you create a dbspace, you use a logical name and a physical name (logical AS physical) CREATE DBSPACE SIZE ©2000 Sybase, Inc. 29 ■ The default is to add space to the IQ Store. ■ The size is in MB, from 1 to 128,000, and either raw partition or operating system file. You can only specify SIZE for the IQ Store and the IQ Temporary Store, not the Catalog Store. ■ A database can have up to 65,536 dbspaces, including the initial dbspaces created when you create the database. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4- Creating Databases Enlarging a Database: Sybase Central 1. In the appropriate database, select the Dbspaces folder and double-click Add Dbspace 2. Follow the wizard to add a dbspace: • Enter the dbspace name • Click the type of data to be stored: IQ or IQ Temporary • Enter the filename and size (optional) • Click OK 4-30 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Decreasing a Database Drops the dbspace ■ A dbspace containing data cannot be dropped ■ dbspaces must be dropped in the reverse order they were created ■ Cannot drop any of the four initial dbspaces ■ Syntax: DROP DBSPACE dbspace-name ■ Example: DROP DBSPACE mydb_tmp_2 Because of the way ASIQ fills dbspaces with data, it is unlikely that you will be able to drop the last dbspace, especially if disk striping is used. To find out if you can drop a dbspace, run sp_iqstatus. Look at the DB Blocks value and compare this value to the Main IQ Blocks used (or Temporary) to see whether the Max block number is in the dbspace. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4-31 Creating Databases Dropping a Database Removes a Database and All of Its Contents ■ Syntax: DROP DATABASE db-filename m Example: DROP DATABASE 'D:\mydb\mydb.db' ■ Drops database mydb m You must specify the database file name you defined during the CREATE DATABASE operation ■ The database must be stopped before you can drop it 4-32 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Other Useful Stored Procedures ■ sp_iqcheckdb • Checks the validity of the current database ■ sp_iqdbsize • Lists the size of the current database ■ sp_iqdbstatistics • Contains statistics for the main IQ Store ©2000 Sybase, Inc. 33 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4- Creating Databases sp_iqdbsize For more information on sp_iqdbsize and other stored procedures, see Chapter 13 of the ASIQ Reference Manual. 4-34 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Databases Summary ■ Determine the device type, either file or raw. ■ Determine approximate database size. ■ To create a database, use CREATE DATABASE. ■ To view database particulars, use sp_iqstatus. ■ To drop the database, use DROP DATABASE. ■ To enlarge the database, use CREATE DBSPACE. ■ To decrease the database, use DROP DBSPACE. ©2000 Sybase, Inc. 35 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 4- Creating Databases Lab 4: Databases Exercise Overview Topics ■ ■ . . CREATE DATABASE The four files created after CREATE DATABASE and their locations CREATE DBSPACE, DROP DBSPACE DROP DATABASE Goals This module introduces the process of creating an IQ database. After completing this lab, you should be able to: ■ Create a database ■ Identify the files associated with a database General tasks ■ Using Sybase Central, create an ASIQ database. ■ Check the status of the database. ■ Add a dbspace to the database. Lab Setup ■ 4-36 The ASIQ Server should be installed with the asiqdemo database running. Connectivity to the database should have been verified. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 5 ASIQ Index Types and Datatypes Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Module Overview This module discusses ASIQ indexes, including how they work and guidelines for choosing appropriate types. It also discusses ASIQ datatypes, including range and storage information. Objectives After completing this module, you should be able to: ■ Define the different ASIQ indexes and choose from among them ■ Discuss ASIQ datatypes ©2000 Sybase, Inc. 1 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5- ASIQ Index Types and Datatypes Module Map ■ ASIQ Index Types ■ ASIQ Datatypes 5-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Types of Indexes Used by Typical RDBMSs ■ For most indexed columns, use a balanced-tree (B-tree) index B-tree index ■ ■ B-tree indexes are excellent at finding single-data values. Data that is not relevant to a query is quickly screened out. ■ B-tree indexes are not good at handling columns with few unique values (such as Y/N or M/F). These indexes are quite large and not well suited for large query results. ■ ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-3 ASIQ Index Types and Datatypes ASIQ's Bitmap ndexes ■ Bitmaps represent the given value as a particular bit mask (for example, 0, 1) ■ Efficiently indexes data regardless of cardinality ■ Easier to maintain (no need to drop and build indexes) 5-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Review: ASIQ ndex Characteristics ■ Fast to load, fast to query ■ Compact • Requires less disk space than traditional B-tree indexes • More data can be kept in memory ■ Column-wise storage structures • Key to fast query resolution ■ Each column has one, two, or three indexes ■ Index type selected based on datatype, cardinality, and use of data ■ Each index (access method) is stored and manipulated differently ■ Can incrementally add or delete rows use of data Compact Type, cardinality, and All three aspects of the data are taken into consideration in assigning index types. Data and indexes usually take up less space in ASIQ than in other RDBMSs. Compression depends on the size and nature of the data itself. Incremental update ASIQ is designed for periodic loads (including incremental loads), not realtime updates. Access method ©2000 Sybase, Inc. ASIQ indexes are really data access methods, but they are called indexes. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-5 ASIQ Index Types and Datatypes Review: Four Basic Index Types Each index type is discussed in great detail later. This discussion is intended only as an overview. Fast projection 5-6 Also referred to as the default index. This index has two subtypes: Fast Fast Projection (FFP) and Fast Fast Fast Projection (FFFP). Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Fast Projection (FP) A Column's Raw Data Is Compressed ■ Default column storage, automatically created by ASIQ, cannot be removed ■ Placed on all columns: needed for SELECT list columns, string searches, ad-hoc table joins ■ Typically, you supplement this default index with one or more of the other ASIQ index types ■ Used with wildcard string searching—for example, LIKE '%sys%' ■ Good for calculation expressions—for example, SUM (A + B) ■ Only index that is valid for BIT datatype and VARCHAR >255 ■ Data column examples: • Address • Name • Text descriptions • Project descriptions (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-7 ASIQ Index Types and Datatypes Fast Projection (FP) Subtype: Fast Fast Projection (FFP) ■ Automatically created when you use IQ UNIQUE parameter on CREATE TABLE command • IQ UNIQUE defines the discrete values for the column • Discussed further in Module 6, "Creating Tables and Indexes" ■ If fewer than 256 values in a column, data is stored as Fast Fast Projection (FFP) instead of FP • One-byte look-up table • Will create a FFFP after 256 values are detected ■ The optimizer may use the FFP in terms of distinct values to determine query plans (continued . . .) 5-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Fast Projection (FP) Subtype: Fast Fast Fast Projection (FFFP) custjype ■ Automatically created when you use IQ UNIQUE parameter on CREATE TABLE command • IQ UNIQUE defines the discrete values for the column • Discussed further in Module 6, "Creating Tables and Indexes" ■ If more than 255 and fewer than 65,536 values in a column, data will be stored as FFFP instead of FP • Two-byte look-up table • Will revert to FP after 65,536 values are detected ■ The optimizer may use the FFFP in terms of distinct values to determine query plans ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-9 ASIQ Index Types and Datatypes Low Fast (LF) Bitmap Index Used with Low-Cardinality Data ■ A series of value-based bitmaps used for processing all queries ■ Ideal for columns with a low number of unique values (<1500) ■ Used with the following query operations: • Search arguments in WHERE clause • Joins • GROUP BY • ORDER BY ■ Data column examples: • Male/female • Yesno • Product name • State or province • Date (if fewer than 1500 distinct values) A LF index will allow a maximum of 10,000 distinct values, although 1,500 distinct values is the recommended cutoff. A load will fail if more than 10,000 unique values are inserted. 5-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes High Non Group (HNG) Bit-Wise Index Optimized for Range Searches and Aggregate Functions ■ Example: SELECT SUM(sales) FROM customer ■ A non-value based bitmap ideal for operations involving ranges or aggregations ■ For High and Low Cardinality data ■ Ideal for columns used in: • Ranges • BETWEEN • SUM() and AVG() functions ■ Examples: • Date • Amount • Quantity ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-11 ASIQ Index Types and Datatypes High Group (HG) ASIQ Index Used for High-Cardinality Data ■ Enhanced B-tree index to process equality and GROUP BY operations on high-cardinality data ■ Needed for columns with a high number of unique values (>1500) ■ Used with the following query operations: • Search arguments in WHERE clause • Joins • GROUP BY • ORDER BY ■ A HG index created as UNIQUE or as a PRIMARY KEY will not have a G-Array structure and will use less space ■ Data column examples: • Airport code • Product code • Employee ID 5-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Generic Method for Indexing Columns Four Basic Steps ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-13 ASIQ Index Types and Datatypes Combining Index Types ■ Reasonable combinations are marked with a Prior to ASIQ 12.0 ■ ■ 5-14 In previous versions, usually two indexes were placed on each column—an FP and another index. This is no longer true. Some columns will have up to three indexes: the FP and two other indexes. In previous versions of ASIQ (prior to 12), an HG contained an HNG index; therefore, you did not want to put both an HG and HNG on the same column. This is no longer true. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Fast Indexes ■ LF and HG indexes are considered "fast" indexes ■ Fastest of all the indexes ■ ASIQ internally knows the cardinality ■ Will have the best performance ■ Still important to use HNG and FP where appropriate ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-15 ASIQ Index Types and Datatypes Step 1: By Default, an FP Index Is on Each Column ■ Every column has the default index (FP) • CREATE TABLE command builds this index • Cannot be removed ■ This index is used during a query when no other index is defined ■ This is the fastest structure for producing the original column data ■ Performance is still faster than for most RDBMSs because only one column of data is fetched ■ No additional indexes are need for columns that will be used only for projection or columns with the BIT or large VARCHAR (>255) datatype In most cases, one or two additional indexes are assigned to each column to provide the flexibility to handle different types of queries. CREATE TABLE 5-16 The syntax for CREATE TABLE is defined in Module 6, "Creating Tables and Indexes." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Step 2: Create LF on Low-Cardinality Columns ■ Create an LF index on any column with <1500 distinct values that is used in: • A join (ad-hoc or join index) • SELECT statement with functions min, max, count, or count(distinct) • WHERE clause predicates: equalityinequality, in list, EXISTS • GROUP BY • ORDER BY ■ Examples: state gender department Join index ■ This is a index that physically stores the join information in the database. See Module 13, "Joins." ■ Cardinality can be determined by running GROUP BY queries on raw data loaded into FPs. If you have trouble determining the data cardinality and/or are unable to determine how the data will be used, the initial load can be done with only an FP index and additional indexes can be added later without reloading all the data. ■ ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-17 ASIQ Index Types and Datatypes Step 3: Create HG on High-Cardinality Columns ■ Create an HG index on any column with >1500 distinct values that is used in: • A join (ad-hoc or join index) • SELECT statement with functions min, max, count, or count(distinct) • WHERE clause predicates: equalityinequality, in list, EXISTS • GROUP BY • ORDER BY 5-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Step 4: Create HNG, If Needed ■ Create an HNG index on all columns used: • In BETWEEN or RANGE comparisons • With AVG() or SUM() functions ■ Examples ... where sold_date between '1/5/99' and '2/5/99' ... where revenue > 10 0 0 SELECT sum(revenue) from ... ...where customer_name like 'Syb%' ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-19 ASIQ Index Types and Datatypes Case Study ■ How would you index the following table without knowing the query mix? Orders ■ Solutions on next page 5-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Case Study: Solutions ■ How would you index the following table without knowing the query mix? Orders 1. Every column gets the FP index, by default 2. Low-cardinality columns get an LF index that are used in: • Join (ad-hoc or oin index) • SELECT statement with min, max, count, count(distinct) • WHERE clause predicates: equalityinequality, in list, EXISTS • GROUP BY and ORDER BY 3. High-cardinality columns get an HG index in same situations as step 2 (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-21 ASIQ Index Types and Datatypes Case Study: Solutions 4. HNG index on columns that are used in: • BETWEEN or RANGE comparisons • With AVG() or SUM() functions Note: Because we do not know the query mix there are other possible index choices. How would the previous index choices change based on the following query? ■ Sample query select avg(quantity), order_date from Orders where order_date between '1/1/98' and '12/31/98' group by order_date • Frequency = 10,000/yr Solutions 5-22 Sample query: ■ Add an HG index on order_date to support the GROUP BY. HNG index will be useful for range search. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Module Map • ASIQ Index Types ■ ASIQ Datatypes ©2000 Sybase, Inc. 23 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5- ASIQ Index Types and Datatypes ASIQ Data Types (continued . . .) VARCHAR > 255 ■ ■ ■ ■ ■ 5-24 Only an FP index is allowed on any VARCHAR column longer than 255. Only LIKE query predicates and SUBSTR functions are supported. There is no storage advantage for choosing VARCHAR over CHAR. There is no performance advantage for choosing VARCHAR over CHAR. UNSIGNED INT is best for primary keys. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes ASIQ Datatypes (continued . . .) ■ ■ The display of timestamp data outside the range of 1600-02-28 23:59:59 to 7911-01-01 00.00:00 may be incomplete, but the complete datetime value is stored in the database. You can see the complete value by first converting it to a character string. FLOAT or REAL A HNG index in not allowed on any FLOAT or REAL. SMALLDATETIME DATETIME TIMESTAMP These are identical datatypes. DATETIME & SMALLDATETIME are user-defined datatypes with a datatype of TIMESTAMP. These were added for compatibility with ASE. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-25 ASIQ Index Types and Datatypes ASIQ Datatypes You should avoid defaulting precision and scale settings for NUMERIC and DECIMAL datatypes, because these are different values in ASIQ, ASE, and ASA. DOUBLE An HNG index is not allowed on any DOUBLE. MONEY SMALLMONEY MONEY and SMALLMONEY are user-defined datatypes with an underlying datatype of NUMERIC. These were added for compatibility with ASE MONEY = NUMERIC(19,4) SMALLMONEY = NUMERIC(10,4) 5-26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes User-Defined Datatypes Aliases for Built-in Datatypes ■ Created using the CREATE DOMAIN statement • Syntax: CREATE DOMAIN domain_name system_datatype • Example 1: CREATE DOMAIN ename CHAR(35) ■ Can also be created using sp_addtype stored procedure • Syntax: sp_addtype type_name, system_datatype • Example 2: sp_addtype "ssn", "varchar(11)" Example 1 CREATE TABLE employee (employee_id int, employee_name ename) drop domain ■ ■ To drop a user-defined type, use DROP DOMAIN. Can be carried out only if the datatype is not in use. sp_droptype ■ ■ To drop a user-defined type, use sp_droptype. Can be carried out only if the datatype is not in use. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5-27 ASIQ Index Types and Datatypes Summary ■ Choosing ASIQ index types • General methodology based on cardinality, joins, and query use ■ ASIQ datatypes • Choose appropriate datatypes when creating ASIQ tables 5-28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Index Types and Datatypes Lab 5: ASIQ Indexing and Datatypes Exercise Overview Topics ■ Read the case study information for the megaphone database . ASIQ index types: FP, LF, HNG, HG ■ Cardinality of columns ■ ASIQ datatypes ■ SQL queries Goals This module introduces the various types of ASIQ indexes. After completing this lab, you should be able to: ■ Correctly determine the index types General tasks Using a case study approach: ■ Read the case study information. ■ Examine the queries. ■ Identify and assign LF indexes. ■ Identify and assign HG indexes. ■ Identify and assign HNG indexes. ■ Perform a datatype matching game. Case study ■ ©2000 Sybase, Inc. 29 The megaphone database. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 5- 6 Creating Tables and Indexes Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Module Overview This module describes how to create ASIQ tables and indexes using the correct syntax. It also covers how to create ASIQ views using the correct syntax. Objectives After completing this module, you should be able to: ■ Create, drop, and alter tables ■ Create/drop indexes ■ Create views ■ Make scripts ©2000 Sybase, Inc. 1 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6- Creating Tables and Indexes Steps for Deploying an ASIQ Installation • Properly plan and size the database • Create ASIQ database(s) • Choose ASIQ datatypes and index types for each column ■ Create ASIQ tables ■ Create ASIQ indexes >-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Module Map ■ Examining Three Types of Tables: • Base Tables • Local Temporary Tables • Global Temporary Tables ■ Creating Views ■ Creating Indexes All of these topics are discussed in this module. Base tables ■ ■ Local temporary tables . Global temporary tables ■ ■ ©2000 Sybase, Inc. Sometimes called main or permanent tables. Stored in the main IQ Store and a permanent part of the database. Must be dropped explicitly. Use the CREATE TABLE statement to create a base table. Use the DECLARE LOCAL TEMPORARY TABLE statement. Created in the IQ Temporary Store. The table will exist until the connection ends or within a compound statement in which it is declared. This table is completely inaccessible to other users. Use the GLOBAL TEMPORARY option of the CREATE TABLE statement. The table will exist in the database until it is explicitly removed. Created in the IQ Temporary Store. Each user will have a separate instance of the data in a global temporary table. Those rows are visible only to the connection that inserts them. They are deleted when the connection ends. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-3 Creating Tables and Indexes Create Tables in the ASIQ Database Clients ASIQ table 6-4 ■ ■ Remember that this is a logical table and does not contain data. The ASIQ table definition is stored in the IQ Catalog Store. The data is stored in indexes in the IQ Store. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes CREATE TABLE Simple Example ■ Translate entities and attributes to tables and columns ■ Determine column characteristics • Name • Datatype • Properties ■ Example: CREATE TABLE employee (emp_id int NOT NULL ,lname varchar(30) NULL ,fname varchar(30) NULL ,salary money NULL) ASIQ default The ASIQ default setting is to allow NULLs (ANSI standard). This can be changed using the ALLOW_NULLS_BY_DEFAULT option, and setting it to OFF. Column limit The number of columns allowed in a table is 10,000. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-5 Creating Tables and Indexes Building Upon CREATE TABLE... Column Constraints ■ IQ UNIQUE • Defines the approximate number of unique values for a column ■ UNIQUE • Allows a value to occur once in a column • Creates an HG index, by default ■ PRIMARY KEY • Same as UNIQUE constraint except that a table can have only one PRIMARY KEY constraint ■ Examples of each to follow. ■ ASIQ does not enforce multicolumn (table-level) UNIQUE and PRIMARY KEY constraints. Also, ASIQ does not enforce REFERENCES and CHECK constraints, column or table level. See Fast Track to Adaptive Server Enterprise documentation for more information on these constraints. . 6-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes CREATE TABLE - IQ UNIQUE CREATE TABLE customer (customer_id int NOT NULL, cust_type char(4) IQ UNIQUE (30), postalcode char(9) NULL) ■ IQ UNIQUE constraint defines the approximate cardinality of a column • Used for internal FP index storage optimization • <256 values - Single-byte lookup table (FFP index) • >255 and <65536 - Two-byte lookup table (FFFP index) • Default value is 65,537 ■ Use this constraint for optimal storage and performance • You will use less disk space • Optimizer will make better decisions ■ ■ ■ Example ©2000 Sybase, Inc. Sybase recommends that you specify IQ UNIQUE whenever you have a reasonable idea of how many unique values a column will hold. Do not specify IQ UNIQUE if you do not have a good estimate for the number of unique values. The optimizer will use this value (if a LF or HG is not defined on that column) in the query plan. Remember that a LF or HG store column statistics and those will be used first, if available. ■ If you don't set the IQ UNIQUE in CREATE TABLE, you will get the plain FP index. If the IQ UNIQUE indicates a FFP to be built, but the number of values during a load are exceeded, an FFFP will be created if the value is < 65,536. ■ In this example, the cust_type has 30 expected distinct values. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 Creating Tables and Indexes CREATE TABLE-UNIQUE CREATE TABLE stores (store_id char(4) NOT NULL ,store_name varchar(20) NOT NULL ,store_address varchar(40) NOT NULL ,unique (store_id )) ■ UNIQUE constraint creates a unique HG index on the column • No G-Array with the HG index • If a column is low cardinality, consider creating a unique LF index instead of a UNIQUE column constraint ■ Can be used only on a single column ■ The optimizer will use the UNIQUE constraint when developing a query plan, which is the same as creating a unique HG separately Example Can also be defined as follows: CREATE TABLE stores (store_id char (4) UNIQUE ,store_name varchar(20) NOT NULL ,store_address varchar(40) NOT NULL) This is the column-level syntax of the UNIQUE constraint. ■ ■ 6-8 ASIQ does not enforce multicolumn uniqueness. The column cannot contain any NULL values. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes CREATE TABLE - PRIMARY KEY CREATE TABLE product (product_code CHAR(5) NOT NULL ,product VARCHAR(25) NOT NULL ,price MONEY NULL ,primary key (product_code)) ■ PRIMARY KEY constraint creates a unique HG index on the column • No G-Array with the HG index • If a column is low cardinality, consider creating a unique LF index instead of a PRIMARY KEY column constraint ■ Can be used only on single-column primary keys ■ The optimizer will use the PRIMARY KEY constraint when developing a query plan, which is the same as creating a unique HG index separately Example Can also be defined as follows: CREATE TABLE product (product_code CHAR(5) PRIMARY KEY ,product VARCHAR(25) NOT NULL ,price MONEY NULL) This is the column-level syntax of the PRIMARY KEY constraint. ■ ■ ■ ©2000 Sybase, Inc. ASIQ does not enforce multicolumn primary keys. The column cannot contain any NULL values. You cannot specify the PRIMARY KEY and UNIQUE constraints for the same column. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 Creating Tables and Indexes Building Upon CREATE TABLE... FOREIGN KEY Constraint ■ Specifies which column(s) in the created table compare with the columns in the referenced list ■ This constraint is not enforced in ASIQ, but will provide improved query optimization ■ Should be used only if there are no orphans • Meaning that there are corresponding values in the referencing table • If there are orphans, ASIQ may provide incorrect query results ■ Can be a column-level constraint or a table-level constraint ■ When defined in tables, permits the use of the KEY JOIN syntax in queries Column-level and table-level constraints ■ ■ KEY JOIN 6-10 Column-level constraint: • If there is only one column in the table to be compared with a column in the referenced table, use a column-level constraint. Table-level constraint: • If there is more than one column in the table to be compared with the columns in the reference table, use a table-level constraint. • A composite key consists of more than one column. This is an optional method for creating table joins. Discussed further in Module 11, "Using ASIQ." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes FOREIGN KEY Constraint Column-Level Example CREATE TABLE titles (title_id tid not null ,title varchar(80) null ,pub_id char(4) null references publishers(pub_id) UNENFORCED ,notes varchar9200) null) ■ You must specify the UNENFORCED keyword • ASIQ does not check this constraint during insertion or deletion to this table; used for query optimization only ■ The publishers table must exist and have a unique index on pub_id (continued . . .) Column-level syntax REFERENCES primary-table-name [(primary-column-name)] Notes ■ The table name following references must already have a PRIMARY KEY or UNIQUE constraint defined on the columns referenced. Dropping constraints ■ To remove a constraint, use ALTER TABLE, which is discussed later in this module. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-11 Creating Tables and Indexes FOREIGN KEY Constraint Table-Level Example CREATE TABLE salesdetail (stor_id char(4) ,ord_num varchar(2 0) ,title_id tid ,qty smallint not not not not null null null null ,FOREIGN KEY(stor_id, ord_num) REFERENCES sales (stor_id, ord_num) UNENFORCED ,FOREIGN KEY(title_id) REFERENCES titles (title_id) UNENFORCED) The above example does not imply a composite index. Remember that a foreign key is not enforced. Therefore, by defining foreign keys in ASIQ is only useful for documentation purposes. 6-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Syntax: CREATE TABLE ■ Create a table in the database CREATE [ GLOBAL TEMPORARY ] TABLE [ owner.]table-name ... ( column-definition [ column-constraint]... [, column-definition [column-constraint] ...]) [, table-constraint ] ...) column-definition column-constraint column-name data-type [ [NOT] NULL] { UNIQUE | PRIMARY KEY | IQ UNIQUE (integer) REFERENCES table-name [(column-name)] UNENFORCED} The REFERENCES (FOREIGN KEY column-level) constraint is not enforced but will be used for query optimization. table-constraint ©2000 Sybase, Inc. Table constraints are not enforced. You can specify UNIQUE, PRIMARY KEY, and CHECK constraints at the table level, but these are not currently useful in an ASIQ implementation. The FOREIGN KEY constraint will be used for query optimization. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-13 Creating Tables and Indexes CREATE TABLE A More Complex Example CREATE TABLE books (isbn char(20) PRIMARY KEY IQ UNIQUE (150000) ,copyright_date date NOT NULL ,title char(100) REFERENCES titles (title) UNENFORCED ,author char (50) REFERENCES authors (author) UNENFORCED ,price money NULL) ■ You can combine IQ UNIQUE with the other column constraints (continued . . .) Custom data types 6-14 You can define customized data types for your database. See the CREATE DOMAIN statement in Module 5, "ASIQ Index Types and Datatypes." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes CREATE TABLE Automatic Indexing ■ ASIQ automatically creates an FP index on each column • If you specify an IQ UNIQUE count < = 255, loading will be optimized to an FFP • If you specify an IQ UNIQUE count >= 256 and <= 65,536, loading will be optimized to an FFFP • If you specify an IQ UNIQUE count >= 65,537 (or do not use IQ UNIQUE), you will create a regular FP index ■ An HG index will be created on a column with a PRIMARY KEY or UNIQUE single-column constraint • This will be an HG index without a G-Array • Works well for a single column with high cardinality • Must alter table and drop primary key constraint to drop the HG index Do not confuse UNIQUE & IQ UNIQUE ■ Auto Indexing ■ ©2000 Sybase, Inc. ■ UNIQUE allows a value to occur only once in a column and must be defined as NOT NULL. IQ UNIQUE is an approximation of the number of distinct values. There is a database option called AUTOINDEXING, this may be set to ON or OFF. By default, it is set ON. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 6-15 Creating Tables and Indexes Creating a Table with Sybase Central 1. Connect to the database 2. Click the Tables folder 3. Double-click Add Table 4. Enter a name for the table 5. Enter the columns, datatypes, and other attributes 6. Click Save ■ ■ ■ 6-16 Do not create multicolumn primary keys (very easy to do in Sybase Central). You will seemingly have a multicolumn HG index on those columns, but that index does not actually get created. If you do create a multicolumn primary key, you must alter the table and drop the primary key constraint for the table and then create the individual indexes. A CREATE TABLE example using Sybase Central follows on the next several foils. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Sybase Central: Steps 1-3 1. Connect to the database • Select Tools->Connect->Adaptive Server IQ • Enter user ID, password, port number 2. Click the Tables folder 3. Double-click Add Table ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-17 Creating Tables and Indexes Sybase Central: Steps 4-6 4. Enter a name for the table 5. Enter the column names, datatypes, and other attributes 6. To create the table in the database, click the Save icon in the toolbar 6-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Sybase Central Specifying IQ UNIQUE ■ Click the Advanced Column Properties icon in the toolbar (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-19 Creating Tables and Indexes Sybase Central Specifying a Primary Key ■ Click the Key icon in the Table window ■ The icon changes to a key symbol with a "P" ■ When you click the Save icon in the toolbar, the table is created and the selected column will have an HG index created on it • It will also have an FP index by default ■ To create a primary key on a column, the column must not allow NULLs. Click the nulls box to remove the checkmark, which indicates that NULLs are allowed. ■ Do not create multicolumn primary keys. The HG index will not be physically created and the table will have to be modified and the correct indexes will have to be added separately. 6-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Vileewing a Tab ■ Syntax: sp_iqtable [table-name] ■ Example: sp_iqtable customer ■ Results: ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-21 Creating Tables and Indexes Altering Tables ■ Partial syntax: ALTER TABLE [owner.] table-name { ADD column-definition [column-constraint]...| ADD table-constraint | MODIFY column-name [NOT] NULL | { DELETE | DROP } column-name | { DELETE | DROP } UNIQUE (column-name [, ...])| { DELETE | DROP } PRIMARY KEY | { DELETE | DROP } FOREIGN KEY | RENAME new-table-name | RENAME column-name TO new-column-name } See the ASIQ Reference Manual for full syntax. Sybase Central 6-22 You can alter tables in Sybase Central by displaying the property sheet. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes ALTER TABLE Examples ■ Add a column: ALTER TABLE customer ADD country char(20) ■ Add a column with a FOREIGN KEY constraint: ALTER TABLE customer ADD sales_contact INTEGER REFERENCES employee (emp_id) UNENFORCED ■ Drop a column • You can safely drop a column in an ASIQ table with indexes ALTER TABLE customer DROP cust title ©2000 Sybase, Inc. 23 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6- Creating Tables and Indexes TRUNCATE TABLE ■ Syntax: TRUNCATE TABLE [owner.]table-name ■ Example: TRUNCATE TABLE customer ■ Deletes all rows from the table ■ Column definitions and constraints remain intact, as well as permissions ■ Rows not entered into the transaction log • Very fast; size of data does not affect speed • Not recoverable This command is reserved for a table owner or you must have Database Administrator authority. ASIQ has a transaction log located in the IQ Main Store (not to be confused with the Catalog Store Transaction Log called dbname.log) which is managed entirely by ASIQ. Further discussion on this transaction log is in Module 12, "ASIQ Operation Data Administration ". Notes 6-24 Disk space for the data becomes available for other uses within the database when you truncate a table. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes DROP TABLE ■ Syntax: DROP TABLE tablename ■ Example: DROP TABLE customer ■ Deletes all records and removes table definition from database ■ Very fast; size of data does not affect speed Notes Disk space for the table and its indexes becomes available for other uses within the database when you drop a table. Sybase Central 1. Connect to the database. 2. Click the Tables folder. 3. Right-click the table and select Delete from the popup menu. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-25 Creating Tables and Indexes Module Map ■ Examining Three Types of Tables: • Base Tables • Local Temporary Tables • Global Temporary Tables ■ Creating Views ■ Creating Indexes ■ Base tables ■ Local temporary tables . Sometimes called main or permanent tables. Stored in the main IQ Store and a permanent part of the database. Must be dropped explicitly. Use the CREATE TABLE statement to create a base table. Use the DECLARE LOCAL TEMPORARY TABLE statement. Created in the IQ Temporary Store. The table will exist until the connection ends or within a compound statement in which it is declared. This table is completely inaccessible to other users. Global temporary tables . Use the GLOBAL TEMPORARY option of the CREATE TABLE statement. The table will exist in the database until it is explicitly removed. Created in the temporary IQ Store. ■ Each user will have a separate instance of the data in a global temporary table. Those rows are visible only to the connection that inserts them. They are deleted when the connection ends. 6-26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Local Temporary Tables: Method 1 ■ Syntax: DECLARE LOCAL TEMPORARY TABLE table-name ...( column-definition [column-constraint] ... [, column-definition [column-constraint] ...]) ...[ ON COMMIT { DELETE | PRESERVE } ROWS ] ■ Example: DECLARE LOCAL TEMPORARY TABLE MyTable (colA int ,colB char(4)) ■ The table will exist until the connection ends or within a compound statement in which it is declared ■ This table is completely inaccessible to other users Notes ■ You cannot use ALTER TABLE on a local temporary table. ON COMMIT ■ Only allowed for temporary tables. By default, the rows of a temporary table are deleted ON COMMIT. ©2000 Sybase, Inc. 27 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6- Creating Tables and Indexes Local Temporary Tables: Method 2 ■ Syntax: CREATE TABLE #table-name ... or SELECT INTO #table-name ■ Example: CREATE TABLE #MyTable (colA int ,colB char (4)) ■ The table will exist until the connection ends or within a compound statement in which it is declared ■ This table is completely inaccessible to other users ■ 6-28 You will only have FP indexes unless you create additional indexes. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Module Map ■ Examining Three Types of Tables: • Base Tables • Local Temporary Tables • Global Temporary Tables ■ Creating Views ■ Creating Indexes Base tables ■ ■ Local temporary tables . Sometimes called main or permanent tables. Stored in the main IQ Store and a permanent part of the database. Must be dropped explicitly. Use the CREATE TABLE statement to create a base table. Use the DECLEARE LOCAL TEMPORARY TABLE statement. Created in the IQ Temporary Store. The table will exist until the connection ends or within a compound statement in which it is declared. This table is completely inaccessible to other users. Global temporary tables . Use the GLOBAL TEMPORARY option of the CREATE TABLE statement. The table will exist in the database until it is explicitly removed. Created in the temporary IQ Store. ■ Each user will have a separate instance of the data in a global temporary table. Those rows are visible only to the connection that inserts them. They are deleted when the connection ends. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-29 Creating Tables and Indexes Global Temporary Tables ■ Syntax: CREATE GLOBAL TEMPORARY TABLE table-name ...( column-definition [column-constraint] ... [, column-definition [column-constraint] ...]) ...[ ON COMMIT { DELETE | PRESERVE } ROWS ] ■ Example: CREATE GLOBAL TEMPORARY TABLE GlobTable (colA int ,colB char(4)) ■ The table will exist in the database until it is explicitly removed ■ Each user will have a separate instance of the data • Those rows are visible only to the connection that inserts them • Those rows are deleted when the connection ends, by default ON COMMIT ■ Allowed only for temporary tables. By default, the rows of a temporary table are deleted ON COMMIT. ■ The database contains one definition of a global temporary table, just like a base table. Each user has rows that are visible only to that connection. ■ You can drop a global temporary table using the DROP TABLE statement. You cannot drop or alter a global temporary table while other connections are using it. ■ 6-30 To create a global temporary table, double-click the Advanced Table property, and select Global Temporary Table. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Module Map • Examining Three Types of Tables: • Base Tables • Local Temporary Tables • Global Temporary Tables ■ Creating Views ■ Creating Indexes ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-31 Creating Tables and Indexes View: Defined A view: • Is a stored SELECT statement that behaves like a table • Does not store data • May SELECT from more than one table ■ ■ 6-32 A view is the derived results of the SELECT statement. You cannot create indexes on a view. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Creating a View: Benefits ■ Improved security • Limits certain columns and/or rows to certain users • Gives users access to views instead of to tables ■ Improved usability • Simplifies and customizes the user's perception • Provides logical data independence ■ Improved performance for views • Optimizer will select a better query plan when doing multiple table joins • Using views with UNION to partition large (deep) fact tables by some time period A Partitioning improves load/delete performance A Easy method for rolling data in and out ▲ Example coming up ... ©2000 Sybase, Inc. 33 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6- Creating Tables and Indexes View: Using Partitioned Tables A view with UNION • Keeps the table together logically • IQ will perform UNION in parallel (if CPU resources are available) 6-34 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes CREATE VIEW Syntax: CREATE VIEW ... [owner.] view-name [(column-name[,...])] ... AS select-without-order-by ... [WITH CHECK OPTION] Example: CREATE VIEW colorado_customer AS SELECT * FROM customer WHERE state = ‘CO' Quotes ■ ■ ■ WITH CHECK OPTION Rejects any updates or inserts to the view that do not meet the criteria of the SELECT. ASIQ currently ignores this option. Sybase Central 1. 2. 3. 4. 5. ©2000 Sybase, Inc. Single quotes are used to indicate strings. Double quotes are used to indicate table or column names. Two single quotes are used to include a single quote inside a string. Connect to the database. Click the Views folder. Double-click Add View. Enter the table and columns to be used. From the File menu, select Execute Script. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-35 Creating Tables and Indexes Views for Performance Join Views ■ Example: CREATE VIEW emp_dept AS SELECT emp_lname, emp_fname, dept_name FROM Employee, Department WHERE Employee.dept_id = Department.dept_id ■ A performance improvement may be seen by using join views instead of performing joins in SELECT statements • The more tables that are joined, the greater the performance gain DROPVIEW DROP VIEW [owner . ] view-name VIEW restrictions A view cannot include an ORDER BY clause. 6-36 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Steps for Deploying an ASIQ Installation • Properly plan and size the database • Create ASIQ database(s) • Map proper ASIQ datatypes and choose index types for columns • Create ASIQ tables ■ Create ASIQ indexes ©2000 Sybase, Inc. 37 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6- Creating Tables and Indexes Create the ASIQ Indexes ■ Indexes are defined on table columns ■ Contain all the data for a column ■ Each column has an FP index by default and usually one or two additional indexes are defined • See Module 5, "ASIQ Indexes and Datatypes," for information on choosing the correct indexes for a column 6-38 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Review: Index Types ■ Four index types: • Fast Projection (FP) • Low Fast (LF) • High Group (HG) • High Non Group (HNG) ■ FP indexes are automatically created on all the columns during the CREATE TABLE operation ■ HG indexes are automatically created on PRIMARY KEY and UNIQUE columns during the CREATE TABLE • HG is created regardless of cardinality ■ All indexes that are automatically created by ASIQ have the prefix ASIQ_... FP The FP index has two subtypes: FFP and FFFP. ©2000 Sybase, Inc. 39 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6- Creating Tables and Indexes Four Options for Creating Indexes ■ CREATE INDEX command ■ Add Index wizard in Sybase Central ■ Create indexes in parallel (after data is loaded) ■ With the UNIQUE or PRIMARY KEY column constraint The first three approaches are discussed in the next several foils. The fourth approach was previously discussed in this module. It is generally more efficient to create all indexes on columns before loading data. 6-40 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes CREATE INDEX: Syntax and Example ■ Syntax: CREATE [UNIQUE] [index-type] INDEX index_name ON [owner] .table_name (column_name) [NOTIFY integer] ■ Example: CREATE HG INDEX cust_customer_id_hg ON customer(customer_id) ■ Creates a High Group index on the customer table for the customer_id column ■ Index names must be unique across the database UNIQUE ■ index-type { HG | HNG | LF } index-name ■ Must be unique for a database. Limited to 128 characters. NOTIFY ■ Gives notification messages after a specified number of records are read for the index. The default is 100,000 records. To turn off, set to0. ©2000 Sybase, Inc. Unique indexes can be created only on LF and HG index types. Recommend using this when possible Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-41 Creating Tables and Indexes CREATE INDEX: Sybase Central 1. Double-click Add Index 2. Follow wizard (continued on next few foils) (continued . . .) 6-42 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes CREATE INDEX: Sybase Central Add Index Wizard 1. Enter name of new index (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-43 Creating Tables and Indexes CREATE INDEX: Sybase Central Add Index Wizard 2. Choose the kind of index (HG, HNG, or LF) • If you choose Low disk, a High group will be created instead • The Low disk index will be removed in the future 3. Specify a notification record number ■ The notification message is associated with inserts, updates and deletes. This number indicates the number of records read before sending a message. (continued . . .) 6-44 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes CREATE INDEX: Sybase Central Add Index Wizard 4. Choose the column in the table the index is placed on 5. Click Finish ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-45 Creating Tables and Indexes CREATE INDEX: Restrictions ■ There is always an FP index on each column • Cannot drop the FP index ■ Can create additional indexes after the data is inserted • Data does not need to be reinserted ■ Index name must be unique in the database Adding additional indexes after the data is inserted is an option. This method of inserting data from an existing index can be slow. It is usually faster to create all the appropriate indexes before inserting data. It may be done when there is insufficient memory for an insert, update or delete. 6-46 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Creating Indexes in Parallel ■ To create new indexes on data loaded in the database in parallel • When additional indexes are needed • System resources (memory/cpu) dictate creating indexes after loading data ■ Syntax: Begin Parallel IQ Create LF index ... Create HG index... End Parallel IQ (continued . . .) ©2000 Sybase, Inc. 47 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6- Creating Tables and Indexes Creating Indexes in Parallel ■ Restrictions • No other DDL statements by any user can be executed while this command is executing • Multiple indexes on the same column will be performed serially • Cannot create indexes on temp tables or global temp tables • Cannot use Sybase Central to create indexes in parallel ■ Performance recommendation • Limit number of indexes to create to the number of CPUs 6-48 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Viewing ASIQ Indexes with sp_iqindex ■ Syntax: sp_iqindex [table-name] ■ Example: sp_iqindex customer ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-49 Creating Tables and Indexes Dropping Indexes ■ Drops the data for that index column ■ Cannot drop the FP index ■ Cannot drop indexes created by the CREATE TABLE command, must alter table ■ Syntax: DROP INDEX [[owner].table-name.] index_name ■ Example: DROP INDEX cust_customer_id_hg Sybase Central 6-50 1. Click the table name, right-clicking to display options. 2. Select the Delete option. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Create and Maintain Scripts Be Able to Automate ASIQ Site Rebuilds ■ Keep all ASIQ DDL commands in a scripts ■ May be useful to create two scripts for each table • Script 1 contains table and index creation • Script 2 contains the load script for the table (coming soon...) ■ Have a CREATE DATABASE script Sybase Central ©2000 Sybase, Inc. Sybase Central does not have the ability to create scripts. Use this tool with caution. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6-51 Creating Tables and Indexes Summary ■ CREATE TABLE • Alter to add or drop columns. • View using sp_iqtable. ■ CREATE INDEX • Usually additional one or two indexes per column besides FP. • Parallel index creation. • View using sp_iqindex. ■ CREATE VIEW ■ Sybase Central • Create/alter/drop tables. • Create/drop indexes. ■ Always create scripts! 6-52 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating Tables and Indexes Lab 6: Creating Tables and Indexes Exercise Overview Topics ■ Use a script to create tables and indexes ■ CREATE TABLE command ■ CREATE INDEX command ■ Viewing tables and indexes using sp_iqtable and sp_iqindex commands Goals This lab introduces the creation of ASIQ tables and indexes. After completing this lab, you should be able to: ■ Create and use a script to create tables and indexes in an ASIQ database General tasks ■ View the creation script ■ Run the script to create the tables and indexes for the megaphone database. ■ View the tables and indexes Lab setup ■ ©2000 Sybase, Inc. 53 This lab assumes that you have created the megaphone ASIQ database. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 6- 7 ASIQ Memory Configuration Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Module Overview This module explains how to properly configure ASIQ memory before loading data. Objectives After completing this module, you should be able to: ■ Identify ASIQ memory components ■ Set ASIQ memory buffer caches ©2000 Sybase, Inc. 1 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7- ASIQ Memory Configuration Sybase ASIQ Memory Components Overview ■ Server memory ■ Buffers ■ Buffer caches • Main buffer cache (IQ Store cache) • Temporary buffer cache (IQ Temporary Store cache) ■ "Active" users 7-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Server Memory ■ ASIQ allocates memory from a single memory pool ■ Used for: • Reading data from disk to resolve queries • Reading data from disk when loading data from flat files • Managing connections, transactions, buffers, and database objects ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-3 ASIQ Memory Configuration Buffers, Page Size, and Blocks Definitions ■ Buffer - A region in memory that holds uncompressed data read from and written to a database ■ Page size - Amount of data swapped in and out of memory • Determined by create database, IQ page size • Automatically determines the data compression • See Module 4, "Creating Databases" ■ Page = Buffer ■ Block - Minimum unit for performing disk I/O • By default, determined by IQ page size ASIQ Page Size (KB) Resulting Block Size (bytes) 1 512 2 512 4 512 8 512 16 1024 32 2048 64 4096 128 8192 256 16,384 512 32,768 7-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Buffer Caches Two Types ■ Main buffer cache • Area in memory for IQ Main Store buffers • Shared by all users ■ Temporary buffer cache • Area in memory used for IQ Temporary Store buffers • Shared by all users Each of these topics is discussed in detail later in the module. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-5 ASIQ Memory Configuration Why Tune Shared Buffer Caches? Reduce Physical I/O If Used Properly ■ Used for all reads and writes ■ Can reduce the amount of physical I/O if: • Multiple readers are accessing the same database • The buffer cache is large to prevent excess thrashing 7-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Main Buffer Cache ■ Initialized when the database is started ■ Default main buffer cache size is 8MB • Too small for most applications ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-7 ASIQ Memory Configuration Temporary Buffer Cache ■ Initialized when the database is started ■ This cache is used for ad-hoc joins, grouping, and sorting ■ Default cache size is 4MB • Too small for most applications 7-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Viewing Buffer Cache Size Use sp_iqstatus Example: Main IQ buffers = 8MB Temporary IQ buffers = 4MB ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-9 ASIQ Memory Configuration "Active" Users ■ Each ASIQ user has a process ■ This process needs about 5MB per "active" user in a database • An active user is one who is accessing or performing a query in the database • The documentation says 10MB, which is on the high side (an active user can range from 1MB to 10MB) 7-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Strategy for Sizing Caches Steps 1. Understand host platform's memory component requirements 2. Calculate ASIQ cache sizes 3. Set buffer caches ©2000 Sybase, Inc. 11 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7- ASIQ Memory Configuration Memory: The Big Picture Step 1 - Understand the Components ■ Operating system and other applications ■ ASIQ Server ■ ASIQ memory overhead ■ ASIQ main buffer cache ■ ASIQ temp buffer cache Detailed discussion of each component follows 7-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Operating System Memory and Other Applications ■ UNIX operating system (OS) • Varies by platform, but typically 60MB ■ NT • OS needs typically 30MB or more • 4MB + 25% of total memory ■ Other applications on the server • Query tool memory needs, if any • Middleware on the server • OLAP (OnLine Application Program) servers ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-13 ASIQ Memory Configuration ASIQ Server ■ Adaptive Server IQ • Varies by platform • Typically, 30MB 7-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration ASIQ Memory Overhead ■ Active users • 5MB each ■ ASIQ load operations • Default 0MB • Control heap memory allocation during a load ■ File system caches • Additional 30% of total memory to handle file buffering (continued . . .) Active user A user who is accessing or querying the database. Load operations The load_memory_MB option allows a user to specify an upper limit on the amount of heap memory subsequent loads can use. File system Thirty percent (30%) is in addition to the OS overheads for file systems. You can avoid this overhead by using raw partitions for your database. 30% may be a little on the high side. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-15 ASIQ Memory Configuration ASIQ Memory Overhead load_memory_MB option ■ Used to specify an upper bound on the amount of heap memory a load will use ■ Help ensure a load will complete even if it incurs degradation in load performance ■ Default is 0 • Meaning that there is no upper limit ■ Allowed values are 0-500MB ■ Recommend setting this value to non-zero to avoid exhausting virtual memory during a load 7-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Side Note on Setti ng Database Options ■ There are several database options which can be set ■ We will introduce them as needed ■ These options change how DBISQL interacts with the database ■ Syntax: SET [ TEMPORARY ] OPTION . . . [userid. | PUBLIC. ] option-name = [option-value] ■ Example on next slide ... ©2000 Sybase, Inc. Administering Adaptive Server IQforthe Data Warehouse, Version 1.0 7-17 ASIQ Memory Configuration load_memory_MB option ■ Every load uses some amount of heap memory ■ If the user-specified limit is lower than required for the load, the user will receive an error ■ The user must increase or turn off the load_memory_MB option ■ Example: SET OPTION LOAD MEMORY MB = 30 0 Turn off Set the value to 0. load_memory_MB option 7-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration ASIQ Main and Temp Buffer Caches Determined after calculating remaining memory Guideline is to split remaining memory between main and temp buffer caches: • 40% main buffer cache • 60% temp buffer cache 40/60 split This is a general rule of thumb. Some applications may be optimal with a split of 50/50 or 60/40. Start with the 40/60 split guideline and watch performance and adjust buffer caches. Refer to Module 15, "Monitoring and Troubleshooting." Maximum memory cache ■ settings ■ . . . . ■ Solaris 32 bit-3.3GB. Solaris 64 bit - Effectively unlimited. Compaq Tru64 (DEC-UNIX) - Effectively unlimited. SGI IRIX - Effectively unlimited. IBM RS6000 AIX - 2GB *. HP UNIX - 3GB *. NT-2.5GB**. * Must use the server startup option -iqsmem to get this much memory. ** WIN NT Enterprise only, 2GB for other WIN NT platforms. Server startup switches ©2000 Sybase, Inc. See Module 2 and 12, "Admin & Performance Guide," for more information. ■ -iqwmem creates a pool of memory that is locked down and cannot be paged. ■ -iqsmem is used to increase available memory. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-19 ASIQ Memory Configuration Strategy for Sizing Buffer Caches Steps 1. Understand host platform memory components - complete 2. Calculate ASIQ cache sizes 3. Set buffer caches 7-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Calculating Memory for Caches on UNIX Step2 Example: UNIX server with 1GB of RAM Memory Use Memory Available with... Amount Used (MB) 1.Total(nMBi) Raw Partitions UNIX File Systems 1000 1000 2. O/S 60 940 940 3. ASIQ Server 30 910 910 4. UFS overhead (30% of step 3) 273 5. ASQ actve users (10 usersIi) 50 860 587 6. load_memory_MB 100 760 487 7. Avaiable for caches 760 487 8. Main cache MB (40% of step 6) 304 195 9. Temp cache MB (60% of step 6) 465 292 Step 7 637 This is the amount of memory remang for the man and temp buffer caches. Steps 8 and 9 The rule of thumb is to allocate 40% of the remainng memory for the main buffer cache and 60% for the temporary buffer cache. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-21 ASIQ Memory Configuration Calculating Memory for Caches on NT Example: NT server with 512MB of RAM Memory Use Memory Available with... Amount Used (MB) 1.Total(nMBi) Raw Partitions NTFS File Systems 512 512 2. O/S 30 482 482 3. ASIQ Server 30 452 452 4. UFS overhead (30% of step 3) 136 5. ASIQ active users (5 users) 25 427 291 6. load_memory_MB 100 327 191 7. Avaiable for caches 327 191 8. Main cache MB (40% of step 6) 131 76 9. Temp cache MB (60% of step 6) 196 115 Step 7 316 This is the amount of memory remang for the man and temp buffer caches. Steps 8 and 9 The rule of thumb is to allocate 40% of the remainng memory for the main buffer cache and 60% for the temporary buffer cache. 7-22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Query Memory Requirements: Read-Only ■ No insert overhead, so caches can be larger ■ Typically, you would set cache values to include insert operations and not adjust for different environments • Allows for mixed load of inserting and querying the database Changing cache values ©2000 Sybase, Inc. 23 In the previous version of IQ, you would adjust cache values for the l°ad environment and for the query environment. Now, that you can have a database being loaded at the same time it is being queried, the cache values cannot be adjusted as easily. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7- ASIQ Memory Configuration Strategy for Sizing Caches Steps 1. Understand host platform memory components - complete 2. Calculate ASIQ buffer cache sizes - complete 3. Set buffer caches 7-24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Setting Buffer Caches 1. Ensure database is up 2. Set the buffer caches • Do not exceed physical memory • Syntax and examples to follow 3. Make sure all users are disconnected and stop the server 4. Restart the server • New cache sizes are now in effect (continued . . .) Step 1 Start the ASIQ server Step 3 Unix: stop_asiq NT: Open the ASIQ Server icon and click the shutdown button (or stop the service if started by NT Services) If you overallocate memory for caches such that the server will not start, use the following server starting parameters to override the cache sizes: ■ -iqmc x - Overrides the setting for the main cache at server startup. ■ -iqtcy - Overrides the setting for the temp cache at server startup. where x and y are in megabytes of memory. These options can also be put in the configuration file or on the startup command line. ©2000 Sybase, Inc. 25 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7- ASIQ Memory Configuration Setting Buffer Caches Setting the Buffer Cache for the IQ Store ■ Syntax: SET OPTION "PUBLIC".MAIN_CACHE_MEMORY_MB = #_of_MB Setting the Buffer Cache for the IQ Temporary Store ■ Syntax: SET OPTION "PUBLIC".TEMP_CACHE_MEMORY_MB = #_of_MB (continued . . .) Need to have PUBLIC user ID; otherwise, when the database is restarted, it will revert to the default settings. The PUBLIC user ID is a special user used to record PUBLIC permissions. 7-26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Setting Buffer Caches Example: Remember to restart the database. If you set buffer cache sizes higher than your system will accommodate, ASIQ will not open the database. The cache options for start up ---- iqmc and -iqtc—should now be used to reset the defaults and open the database. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-27 ASIQ Memory Configuration Viewing the New Buffer Caches ■ Use sp_iqstatus ■ Main IQ buffers: 40MB ■ Temporary IQ buffers: 60MB 7-28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Memory and Swap Usage Putting It All Together... ■ Pages are being swapped out to disk so that other virtual pages can be moved into physical memory ■ Swapping occurs when an entire process is moved to disk ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-29 ASIQ Memory Configuration Memory Performance ■ Keep I/O to a minimum • Use large buffer caches, if available ■ Avoid operating system paging • Don't overallocate physical memory ■ Monitor memory usage during loads and queries • Running out of memory results in excess swapping Monitoring swap 7-30 ■ UNIX vmstat command. ■ UNIX sar command. ■ Windows NT Task Manager. . IQ UTILITIES tool (Will be discussed in Module 14, "Monitoring and Troubleshooting") Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Memory Configuration Summary Memory Configuration ■ Control memory usage by setting IQ page size during create database. ■ Calculate the memory available for cache sizes: • Adust main and temp caches accordingly. • Do not overallocate physical memory. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 7-31 ASIQ Memory Configuration Lab 7: Memory Configuration Exercise Overview Topics How to view buffer cache sizes: sp_iqstatus SET OPTION "PUBLIC".MAIN_CACHE_MEMORY_MB SET OPTION "PUBLIC".TEMP_CACHE_MEMORY_MB Goals General tasks Lab setup 7-32 This lab explains how to configure ASIQ before loading. After completing this lab, you should be able to: ■ Properly resize main and temp buffer cache sizes ■ Restart the server with the new values ■ View the current cache sizes. ■ Reset the main and temporary caches to new values. ■ Restart the server. ■ View the new cache sizes. ■ This lab assumes that the ASIQ Server is up and running with the megaphone database. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 8 Loading Data from Files Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Module Overview This module explains how to bulk load tables from flat files. It also introduces the LOAD TABLE, UPDATE and DELETE commands. Objectives After completing this module, you should be able to: ■ Load from flat files with fixed-length and variable-length fields ■ Describe incremental loads and deletes Basic loading techniques ■ This module covers fixed- and variable-length flat-file loads. Advanced loading techniques ■ Module 9, "Advanced Data Loading from Files," covers: • Loading from multiple files. • Partial-width loads. • Adding a dbspace during a load. Insert techniques ■ Module 10, "Loading Data Using the INSERT Command," covers inserting from foreign databases. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-1 Loading Data from Files Data Sources ASIQ Can Insert Data into Tables from. ■ Flat files • Fixed-width • Variable-width ■ ASE tables ■ Other ASIQ tables ■ Other databases on remote servers ■ Direct entry ■ Tools 8-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Table Loading Three Options ■ LOAD TABLE • Loads data from files ■ INSERT FROM SELECT • Loads information from databases on the same server or remote server ■ INSERT VALUES • Inserts data "manually" into specified table columns Table loading ©2000 Sybase, Inc. ■ The LOAD TABLE command is covered in this module. ■ Module 10, "Loading Data Using the INSERT Command," covers: • INSERT FROM SELECT command. • INSERT VALUES command. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-3 Loading Data from Files Data Loading ■ Multiple users can query a database table while one user loads or inserts data into that table ■ Multiple users can update the database concurrently • Must be inserting or deleting from different tables • Performance needs to be considered during large updates ■ Must have permissions to modify the table or have Database Administrator authority 8-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Simple Example: Flat-File Load Example: ■ Assumes the width of input columns matches the width of columns in the employee table ■ No explicit data conversion is needed employee table CREATE TABLE employee (employee_id char (4) ,employee_lname char (30) ,employee_fname char (30) ESCAPES OFF QUOTES OFF Required commands for ASIQ. Futher detail on page 8-23. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-5 Loading Data from Files Adding Rows with LOAD TABLE ■ LOAD TABLE appends the contents of the file to the existing rows ■ It does not replace any existing rows ■ To empty out an existing table and reload it, use TRUNCATE TABLE TRUNCATE TABLE 8-6 For syntax, see Module 6, "Creating Tables and Indexes." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files LOAD TABLE Command: Partial Syntax LOAD TABLE [owner].table-name [ ( load-specification, ...)] FROM 'filename-string', ... [ FORMAT { 'ascii' | 'binary' } ] ... [ DELIMITED BY string ] ... [ STRIP { ON | OFF } ] ... [ QUOTES { ON | OFF } ] ... [ ESCAPES { ON | OFF } ] [ ESCAPE CHARACTER character ] [ WITH CHECKPOINT ON | OFF ] ... [ loadoptions ] load-specification {column-name [ column - spec ] | FILLER (filler-type) } column-spec { ASCII (input-width) | BINARY [ WITH NULL BYTE ] | PREFIX { 1 | 2 | 4 } | 'delimiter-string' | DATE (input-dateformat) | TIME (input-time-format) | DATETIME (input-datetime-format)} [ NULL ( { BLANKS | ZEROS | 'literal',...} ) ] ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-7 Loading Datafrom Files Module Map LOAD TABLE Syntax ■ load-specification / column-spec ■ FROM clause ■ load-options Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files load-specification / column-spec Specify the Column Name with a column-spec or FILLER ■ Syntax: {column-name [column-spec]|FILLER(filler-type)} m FILLER (filler-type) • Indicates specified fields to skip in the source input file ■ Example: LOAD TABLE books (FILLER(50) , .... • Ignore the first 50 characters of the data file when loading the books table column-spec ©2000 Sybase, Inc. See the next foil. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-9 Loading Data from Files column-spec Specifies the Column Format of the Input ■ ASCII(number_bytes_wide) or quoted field delimiter • Specifies width of ASCII input columns ■ DATE, TIME, DATETIME, TIMESTAMP (format) • Converts ASCII datetime input ■ NULLS ({ BLANKS | ZEROS I literal' [, 'literal']...}) • Specifies which input values to convert to NULL on insert These topics are covered in detail on the following pages. 8-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Inserting Using Fixed-Width Field Specification ASCII column-spec with an Integer-Width Value ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-11 Loading Data from Files Inserting Variable-Length Fields Specify ASCII column-spec with a delimiter_string 8-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Example: Loading from a Character File Variable-Length Fields, Pipe Delimited \x0a ©2000 Sybase, Inc. This is the delimiter for a new line, used with DBISQL. If you are using Open Client (ISQL), you use '\n'. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-13 Loading Data from Files Date and Datetime Considerations ■ For date and datetime columns coming from character fields, use the DATE and DATETIME functions ■ DATE column-spec • DATE uses 4 bytes • January 1, 0001 to December 31, 9999 ■ DATETIME column-spec • DATETIME uses 8 bytes of storage • Default format: YYYY-MM-DD hh:mm:sssssss ■ BCP binary date formats are not supported • Use character (-c) formats when BCP-ing out • Use a format file when dealing with dates (continued . . .) Examples follow on the next foil. Notes 8-14 BCP a few test rows and do a test load into ASIQ before doing all rows. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Date and Datetime Considerations ■ Examples of supported input formats Notes ■ ■ ©2000 Sybase, Inc. For AM/PM in the DATETIME format, you can specify either AM or PM as a placeholder and the correct AM/PM will be substituted. For example, you might have another input data row of 0115199409:23:00PM and use the same INSERT_CONVERSION_OPTION as above: DATETIME(MMDDY Y Y Yhh: mm: ss AM). Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-15 Loading Data from Files A Word About NULL ■ Which values to convert to NULL at time of insert ■ Destination column must allow NULLs ■ Example: Syntax NULL ({ BLANKS | ZEROS | 'literal'...}) BLANKS ■ Indicates that blanks convert to NULLs. ZEROS ■ Indicates that binary zeros convert to NULLs. literal ■ Indicates that literals convert to NULLs. You can list up to 20 literal values. 8-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Module Map LOAD TABLE Syntax • load-specification / column-spec ■ FROM clause ■ load-options ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-17 Loading Data from Files FROM Clause ■ Syntax: FROM 'filename-string', . . . ■ The filename-string is passed to the server as a string • Subject to formatting requirements • To indicate directory paths in NT, the backslash character (\) must be represented by two backslashes ■ Example: FROM ' C : \\asiqdata\\input.dat' ■ This example shows the file to be on the same server as the ASIQ server \\ ■ ■ 8-18 ASIQ treats the leading backslash in a string as an escape character when the backslash precedes an "n," an "x," or another backslash. You must double each backslash required by the NT naming convention. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Module Map LOAD TABLE Syntax • load-specification / column-spec • FROM clause ■ load-options ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-19 Loading Data from Files load-options The complete listing of load-options: ■ Detail to follow 8-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files DELIMITED BY Option ■ Used to specify a global column delimiter • Default delimiter is a comma ■ Must be a string consisting of one ASCII character or its hexadecimal representation ■ Example: LOAD TABLE books ( name, ... ) FROM 'C:\\iq\\books.txt' DELIMITED BY '| ' QUOTES OFF ESCAPES OFF; ■ What about a newline in the file? • This option should be used in conunction with the ROW DELIMITED BY option, coming up ... ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-21 Loading Datafrom Files Inserting Variable-Length Fields Special Characters for Delimiting Variable-Length Fields with DBISQL 8-22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files QUOTES/ESCAPES Options QUOTES option ■ QUOTES is ON by default ■ If you omit a column-spec definition for an input field, the load looks for a quote character ■ You must set this option to OFF for ASIQ ESCAPES option ■ ESCAPES is ON by default ■ If you omit a column-spec definition for an input field, characters following the backslash character are interpreted as special characters ■ You must set this option to OFF for ASIQ ©2000 Sybase, Inc. 23 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8- Loading Data from Files WITH CHECKPOINT Option ■ A Checkpoint flushes the caches out to disk before doing a commit ■ Default setting is OFF ■ If set to ON, a checkpoint is issued after successful completion of the load ■ If not specified and recovery is required, the data file used to load the table is needed ■ Recommend setting this option to ON 8-24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Putting It Together... File Using Special Character-Delimited Fields ■ od -c is a UNIX octal dump in character mode ©2000 Sybase, Inc. 25 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8- Loading Data from Files PREVIEW load-option - Input Layout Description ■ Example: ■ Performs the load and also provides extra information ■ Describes the LOAD TABLE command, not the table definition • Indicates what the load is expecting to read In table 'month', the full width insert of 7 columns will begin at record 1. 8-26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files ROW DELIMITED BY load_option ■ Specifies the end of each row ■ Example: LOAD TABLE lineitem (l_partkey ASCII(4), l_suppkey ASCII(4), l_quantity ASCII(6), l_orderkey ASCII(6)) FROM 'C:\\iq\\archive\\lineitem.txt' ESCAPES OFF QUOTES OFF ROW DELIMITED BY '\x0a' WITH CHECKPOINT ON; ■ You can either specify '\n' or its ASCII value '\x0a' Row delimiter Can be any string from 1 to 4 characters. Caveats for using ROW Can use this option only if all fields within the row: DELIMITED BY Contain NO binary data. ■ ■ Have column delimiters or are ASCII fixed length. ■ Data defined by DATE or DATETIME column spec. ■ Row delimiter must be distinct from column delimiter. What not to do ©2000 Sybase, Inc. LOAD TABLE license (license_id '|', license_description ' | ' , expiration_date ' | ' , renewal_date ' | ' , amt_due '|', amt_paid '|', price_paid '|', discount '\x0a' ) FROM 'C:\\iq\\archive\\lineitem.txt' ROW DELIMITED BY '\x0a' Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-27 Loading Datafrom Files Loading in Parallel ■ Must have ASIQ Version 12.4.2 or higher ■ Much faster than a regular load ■ Must specify the ROW DELIMITED BY in the LOAD TABLE command ■ AND, data must be delimited and have a newline ■ Example: col 1 | col2 | col3 |\n ■ Note: You must have a delimiter before the newline ■ Can be any delimiter 8-28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files More Complex LOAD TABLE Example LOAD TABLE sales (l_orderkey '\x09', l_quantity ASCII(4) NULL("9999"), FILLER(1), l_shipdate DATE('YYYY/MM/DD')) FROM ‘/work/data/sales.t' QUOTES OFF ESCAPES OFF NOTIFY 1000 SKIP 4 ROW DELIMITED BY '\x0a' WITH CHECKPOINT ON; ■ Inserts into sales table from the flat file sales. t m Each row is delimited, load will not be parallel ■ Used with variable- and fixed-width input fields ■ Skips the first four rows ■ Notification message displayed every 1000 rows ■ QUOTES OFF and ESCAPES OFF (required for ASIQ) ■ Load is followed by a checkpoint ©2000 Sybase, Inc. 29 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8- Loading Datafrom Files Module Map LOAD TABLE Syntax • load-specification / column-spec • FROM clause • load-options 8-30 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files What Happens During a load Session? ■ Data inserted into all the indexes for the specified columns ■ If there is an IQ UNIQUE constraint, the appropriate type of FP (FFP or FFFP) will be created ■ Data converted as specified in the LOAD TABLE statement ■ Notification messages displayed to standard output unless redirected ■ Notifications are made in the IQ Message Log Notification messages ■ ■ FP Note ©2000 Sybase, Inc. ■ ASIQ displays notification messages about your database during insert and load. You can adjust the frequency of these messages, or omit them, with the NOTIFY load-option. The statistics in these messages indicate when you need to perform maintenance and optimization tasks, such as adding more dbspaces. If you exceed the number of values for an FFP specified in the IQ UNIQUE clause, a FP (not an FFFP) is created. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8-31 Loading Data from Files Notification Messages ■ This output file is explained in detail in Module 15, "Performance and Tuning." 8-32 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Transaction Processing and LOAD TABLE ■ A savepoint occurs automatically before the data is loaded ■ If the load is successful, ASIQ releases the savepoint ■ If the load is unsuccessful, the transaction is rolled back to the savepoint For more information on transaction processing, see Module 12, "ASIQ Operational Data Administration." ©2000 Sybase, Inc. 33 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8- Loading Data from Files Deleting Data Three Options ■ DELETE statement • Remove rows that meet specified criteria ■ DROP TABLE • Remove entire table, including data ■ TRUNCATE TABLE • Delete all rows from a table ■ ■ 8-34 For DROP TABLE syntax, see Module 6, "Creating Tables and Indexes." For TRUNCATE TABLE syntax, see Module 6, "Creating Tables and Indexes." Remember that TRUNCATE TABLE is not a logged operation and is very fast. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files DELETE Statement ■ Syntax: DELETE [FROM] [owner.]table-name ... [ FROM table-list ] ... [ WHERE search-condition] ■ Examples: DELETE FROM customer WHERE customer_id IN (SELECT customer_id FROM customer WHERE postalcode = '17349') DELETE FROM books WHERE book id = 105 delete ©2000 Sybase, Inc. 35 ■ ■ Deletes all rows that satisfy the search condition from the table. If no WHERE clause is specified, all rows are deleted. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8- Loading Data from Files DELETE, then LOAD TABLE It may be faster to truncate and load all data • Overhead is involved in performing a delete Can avoid backfilling empty space by using: SET OPTION "PUBLIC."APPEND_LOAD"='ON' This option is OFF by default. 8-36 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files UPDATE Command ■ New with Version 12.4.2 ■ Used to modify rows of a table ■ Table may be a base table or temporary table ■ Base table cannot be part of any join index ■ Syntax: UPDATE table ... SET column-name = expression, ...[ FROM table ] ...[ WHERE search-condition ] . . . [ ORDER BY expression [ASC | DESC ] , ... ] ■ Example: UPDATE employee SET dept_id = 4 0 0 where emp_id = 111; Normally, the order in which rows are updated does not matter. With the NUMBER(*) function, an ordering can be useful to get increasing numbers added to the rows in some specified order. For better performance, do not use the ORDER BY clause in the UPDATE command. ©2000 Sybase, Inc. 37 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8- Loading Data from Files Summary ■ Loading tables from flat files: • Can load flat files with fixed-length fields. • Can load flat files with variable-length fields. ■ Use rule of thumb to estimate load times. ■ Understand delete syntax to delete data from tables. ■ Understand incremental loads. 8-38 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data from Files Lab 8: Loading Data from Files Exercise Overview Topics ■ LOAD TABLE statement ■ DELETE statement ■ TRUNCATE TABLE statement ■ How to insert from a flat file ■ How to delete rows from a table ■ ASCII command ■ Input field terminators ■ Data from ASCII files Goals This lab explains how to load and delete data from ASIQ. After completing this lab, you should be able to: ■ Load data using a variable-length field ASCII file ■ Delete data from a table ■ Truncate a table General tasks Lab setup ©2000 Sybase, Inc. 39 ■ Load the residential_customer table from a variable-width flat file. ■ Interpret the insert notification messages. ■ Delete data from the residential_customer table. ■ Truncate the residential_customer table. ■ Reload the residential_customer table. ■ This lab assumes that you have created the megaphone database and have created all the tables and indexes in that database. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 8- 9 Advanced Data Loading from Files Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Module Overview This module outlines how to build on the LOAD TABLE command. Objectives After completing this module, you should be able to: ■ Load from multiple files ■ Perform partial-width loads ■ Add dbspaces during a load What is covered in this module? Covered in this module: More on the LOAD TABLE command: ■ • Partial-width inserts • Multifile loads Covered in Module 10, "Loading Data Using the INSERT Command" • INSERT FROM SELECT command • INSERT VALUES command ©2000 Sybase, Inc. 1 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9- Advanced Data Loading from Files Review: Options for Tabe Loading ■ LOAD TABLE • Loads data from files ■ INSERT FROM SELECT • Loads information from databases on the same server or remote server ■ INSERT VALUES • Inserts data "manually" into specified table columns 9-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Review: LOAD TABLE Command ■ Partial syntax: LOAD TABLE [owner].table-name [ ( load-specification, ...)] FROM 'filename-string', ... [ FORMAT { 'ascii' | 'binary' } ] ... [ DELIMITED BY string ] ... [ STRIP { ON | OFF } ] ... [ QUOTES { ON | OFF } ] ... [ ESCAPES { ON | OFF } ] [ ESCAPE CHARACTER character ] [ WITH CHECKPOINT ON | OFF ] ... [ loadoptions ] load-spec {column-name [ column - spec ] | FILLER (filler-type) column-spec { ASCII (input-width) | BINARY [ WITH NULL BYTE ] | PREFIX { 1 | 2 | 4 } | 'delimiter-string' | DATE (input-date-format) | TIME (input-time-format) | DATETIME (inputdatetime-format)} [ NULL ( { BLANKS | ZEROS | 'literal',...} ) ] ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-3 Advanced Data Loading from Files Advanced Insert Load Options load options and When to Use Them ■ ON FILE ERROR {ROLLBACK|FINISH|CONTINUE} • Only applies when doing multifile loads • Determines what action to take during a load if a file error occurs ■ START ROW ID row_record_id_# • Sets the starting record to the record number specified • Necessary for partial-width inserts (covered later) 9-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Module Map ■ Load from Multiple Files ■ Partial-Width Loads ■ Adding dbspaces During a Load ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-5 Advanced Data Loading from Files Multifile Load Allows large amounts of data to be loaded in a single pass (continued . . .) Notes ■ ■ 9-6 Specify one or more files for loading. There is no limit to the number of files that you can specify. Files processed sequentially from left to right. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Multifile Load ■ Faster than using multiple inserts ■ Used in LOAD TABLE to specify more than one file in the FROM clause • Can insert multiple files in same insert ■ If ASIQ cannot find or access files, the ON FILE ERROR load option provides the following options: • ROLLBACK - Roll back the entire insert transaction • FINISH - Finish inserting the records and commit • CONTINUE - Go to the new file ON FILE ERROR Specify one of these actions for ASIQ in the event one of the files specified suboptions does not exist or there are permission problems accessing the file. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-7 Advanced Data Loading from Files Example: Multifie Load LOAD TABLE lineitem ( l_shipmode ASCII(15), l_quantity ASCII(8), FILLER(1)) FROM '/d1/MILL1/lineitem.f1', '/d1/MILL1/lineitem.f2' ON FILE ERROR FINISH QUOTES OFF ESCAPES OFF ■ Insert into the lineitem table from two files ■ If there is an error accessing the second file, commit the records from the first file 9-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Module Map • Load from Multiple Files ■ Partial-Width Loads ■ Adding dbspaces During a Load ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-9 Advanced Data Loading from Files Partial-Width Loads Why Perform a Partial-Width Load? Use in these cases: ■ Multiple files, vertically partitioned by a column ■ May need to add a column later ■ Memory requirements do not allow a single-width insert Use either LOAD TABLE or INSERT statement ■ With START ROW ID load option Multiple files ■ Use if you have several files that are horizontally partitioned. Memory requirement ■ Use if you do not have enough memory to perform a full-width insert. Memory management is discussed in Module 7, "ASIQ Memory Configuration." ■ INSERT command 9-10 ■ Discussed in Module 10, "Loading Data Using the INSERT Command." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files What Is a ROWID? ■ One up number assigned to each row ■ Column is part of the table but not displayed, by default ■ To display this column, use the ROWID function ■ Example: select ROWID(table_name), * FROM table name ROWID ©2000 Sybase, Inc. 11 ■ The datatype is a BIGINT. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9- Advanced Data Loading from Files Partial-Width Loads colA colB colC colD In this example, there is a table with data in colA and colB. Now you want to load data into colC and colD. (continued . . .) 9-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Partial-Width Loads ■ Use START ROW ID to specify the starting record ID • Example on left without START ROW ID ■ Steps must be performed in the correct order; otherwise, the results may be incorrect Partial-width load ■ Also known as a vertical load or insert. ■ ■ This is an advanced operation. If you do not perform all the steps correctly in a partial-width insert, you may insert data incorrectly. • Never use this type of insert unless you are an experienced ASIQ user and are familiar with your data. Full-width inserts, which insert into all the column indexes on a table at the same time, ensure row-level integrity and are less error prone. ■ ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-13 Advanced Data Loading from Files Example: Partial-Width Loads This is the table into which the data is inserted CREATE TABLE ( l_partkey l_suppkey l_quantity l_orderkey smallint smallint int lineitem null, null, null, int null) (continued . . .) 9-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Example: Partial-Width Load - The Right Way First load LOAD TABLE lineitem (l_partkey ASCII(4), l_suppkey ASCII(4), FILLER(13)) FROM ‘/d1/MILL1/tt.t' QUOTES OFF ESCAPES OFF WITH CHECKPOINT ON; ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-15 Advanced Data Loading from Files Example: Partial-Width Load - The Right Way Second load LOAD TABLE lineitem (FILLER(8), l_quantity ASCII(6), l_orderkey ASCII(6), FILLER(1)) FROM ‘/d1/MILL1/tt.t' START ROW ID 1 QUOTES OFF ESCAPES OFF WITH CHECKPOINT ON; ■ Note the START ROW ID option used in the second LOAD TABLE statement 9-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Example: Partial-Width Load - The Wrong Way Incorrect partial-width load LOAD TABLE lineitem (l_partkey ASCII(4), l_suppkey ASCII(4), FILLER(13)) FROM ‘/d1/MILL1/tt.t' QUOTES OFF ESCAPES OFF WITH CHECKPOINT ON; LOAD TABLE lineitem (FILLER(8), l_quantity ASCII(6), l_orderkey ASCII(6), FILLER(1)) FROM ‘/d1/MILL1/tt.t' QUOTES OFF ESCAPES OFF WITH CHECKPOINT ON; ■ The result of the SELECT statement below shows that 10 rows are stored instead of the correct number of 5 (10 rows affected) (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-17 Advanced Data Loading from Files Example: Partial-Width Load - The Wrong Way ■ Here is the data from the previous example: What went wrong? How do you fix it? What went wrong? ■ START ROW ID was omitted in the second LOAD TABLE. How do you fix it? ■ Delete records where rowid > 5 and issue second LOAD TABLE statement with START ROW ID 1. Truncate the table and issue both LOAD TABLE statements again. This time, do not forget the START ROW ID 1. ■ 9-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Module Map • Load from Multiple Files • Partial-Width Loads ■ Adding dbspaces During a Load ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-19 Advanced Data Loading from Files Adding dbspaces During a Load What to Do If You Run Out of Space in the Database ■ ASIQ stops loading and suspends the load ■ Add a dbspace; ASIQ will continue the load ■ Example: CREATE DBSPACE mydb_2 AS 'e:\\s2\data\mydb_2.iq' SIZE 200 ■ In Windows NT, create a dbspace called mydb_2 to add 200MB to the IQ Store of the current IQ database (mydb) CREATE DBSPACE dbspace-name AS filename ... [ {IQ STORE | IQ TEMPORARY STORE | CATALOG STORE }] ...[ [SIZE] file-size ] Default Create a dbspace for the IQ Store. You can monitor the amount of space used in a database by looking at the load notification message. 9-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Good Loading Practices ■ Use LOAD TABLE to load from files • Try to load in parallel by using the Row Delimited By option with a delimited flat file, when possible • Load from as many files as possible as one transaction ■ Place data files on separate physical drive from database files ■ Create all IQ indexes before loading data ■ Set up memory for loading • Use Load_Memory_MB option to limit heap size • Provide adequate temp cache for HG indexes ■ Schedule loading during low-usage intervals • Consider the IQ Multiplex option for high-volume systems ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9-21 Advanced Data Loading from Files Summary ■ LOAD TABLE • Fastest method ■ Load flat files together, if available, using multifile load method. • Specify ON FILE ERROR load option. ■ Do partial-width loads with caution. • Specify START ROW ID load option. ■ Remember to check the notification messages during a load. • You may need to add dbspace if the database runs out of room. 9-22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Advanced Data Loading from Files Lab 9: Advanced Loading Data from File Exercise Overview Topics ■ Load data from multiple files ■ Add a dbspace during a load ■ IQ message file and load notification messages ■ sp_iqstatus Goals This lab develops your data-loading skills. After completing this lab, you should be able to: ■ Load from multiple files into an ASIQ database ■ Add a dbspace during a load General tasks Lab setup ©2000 Sybase, Inc. 23 ■ Load the telco_facts table from multiple flat files. ■ Monitor the IQ MSG file during a load. ■ Add a IQ Store dbspace when the database becomes full during a load. ■ Load the month, status, and service tables from a script. ■ Check the space utilization of the database using sp_iqstatus. ■ This lab assumes that you have created the megaphone database and have created tables and indexes in that database. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 9- 10 Loading Data Using the INSERT Command Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command Module Overview This module explores more loading techniques using the INSERT statement. Objectives After completing this module, you should be able to: ■ Perform partial-width inserts ■ Insert from the IQ Main Store ■ Insert directly from a foreign database ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 10-1 Loading Data Using the INSERT Command Table Loading Three Options ■ LOAD TABLE • Loads data from files ■ INSERT from SELECT • Loads information from databases on the same server or remote server ■ INSERT VALUES • Inserts data "manually" into specified table columns LOAD TABLE 1 0 -2 For more information, see Module 8, " Loading Data from Files," and Module 9, "Advanced Data Loading from Files." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command INSERT from SELECT Command ■ Syntax: INSERT [INTO ] [owner.]table-name [ (column-name [, ...]) ] [ LOCATION servername.dbname] ... insert-load-options ... SELECT statement ■ Allows mass insertion into a table with the results of a SELECT statement ■ Example: INSERT INTO dept_head (name, dept) NOTIFY 20 SELECT emp_fname ||'' || emp_lname AS name, dept_name FROM employee JOIN department ON emp_id = dept_head_id [ LIMIT number-of-rows ] [ NOTIFY number-of-rows ] [ SKIP number-of-rows ] [ START ROW ID number ] ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 10-3 Loading Data Using the INSERT Command INSERT VALUES Command ■ Syntax: INSERT [INTO ] [owner.]table-name [ (column-name [, ...]) ] ... VALUES ( expression ... ) ■ Inserts a single row with specified values ■ Example: INSERT INTO department (dept_id, dept_name) VALUES (230, 'Eastern Sales') 10-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command Module Map ■ Partial-Width Inserts ■ Inserting from the IQ Store ■ Inserting Directly from a Foreign Database ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 0 -5 Loading Data Using the INSERT Command Partial-Width Inserts ■ Use either LOAD TABLE or INSERT statement (previous module includes an example of a partial-width insert using the LOAD TABLE statement) • Use START ROW ID insert option • Do not use INSERT VALUES command INSERT VALUES 1 0 -6 Do not use this command for partial-width inserts because you cannot specify START ROW ID using this format. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command Example: Partial-Width Insert - The Right Way The first INSERT INSERT INTO lineitem (l_partkey, l_suppkey) LOCATION ase_srv1.part_db ( SELECT l_partkey, l_suppkey FROM lineitem ORDER BY l_partkey) i Must have Open Client Libraries installed (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 10-7 Loading Data Using the INSERT Command Example: Partial-Width Insert - The Right Way The second INSERT INSERT INTO lineitem (l_quantity, l_orderkey) START ROW ID 1 LOCATION ase_srv1.part_db ( SELECT l_quantity, l_orderkey FROM lineitem ORDER BY l_partkey) ■ Note the START ROW ID option used in the second INSERT statement (5 rows affected) 1 0 -8 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Loading Data Using the INSERT Command Module Map • Partial-Width Inserts ■ Inserting from the IQ Main Store ■ Inserting Directly from a Foreign Database ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 10-9 Loading Data Using the INSERT Command Inserting from the IQ Main Store (continued . . .) Catalog Store 10-10 You can also insert data from the IQ Catalog Store. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command Inserting from the IQ Main Store ■ Syntax: INSERT INTO asiq_table1 (col1, col2, col3,...) [ insert-load-options ] ... select col1, col2, col3 ... from asiq_table2 [WHERE ... ] ■ The table you are inserting into must exist in the database you are connected to (continued . . .) For maximum efficiency, insert as many rows as possible in one INSERT statement. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 10-11 Loading Data Using the INSERT Command Inserting from the IQ Main Store ■ Example: INSERT INTO lineitem (l_partkey, l_suppkey, SELECT l_quantity, l_order_key) l_partkey, l_suppkey, l_quantity, l_order_key FROM partitem ■ This example inserts data into the lineitem table from the already-populated partitem table 10-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command Module Map • Partial-Width Inserts • Inserting from the IQ Main Store ■ Inserting Directly from a Foreign Database ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 10-13 Loading Data Using the INSERT Command Inserting Directly from a Foreign Database The Database Can Be on a Different Computer Client (continued . . .) 10-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command Inserting Directly from a Foreign Database 1. Connect to both databases using the same user ID and password for Unix • Must have an entry for the foreign server in the directory services file 2. On the ASIQ database, issue a statement using this syntax: INSERT INTO asiq_table (col1, col2, col3, ...) LOCATION 'servername.dbname' ( SELECT col1, col2, col3, . . . FROM table ) 3. Issue an explicit COMMIT to commit the insert COMMIT; (continued . . .) Step 1 In NT we have CIS, which permits you to set up an external login to remote servers, so you do not need to have the same user IDs and passwords on both servers. LOCATION ■ ■ ©2000 Sybase, Inc. ASE - The Adaptive Server Enterprise server you are connecting to must exist in the interfaces file on the local machine. Other - Need to have OMNI and DirectConnect access a foreign server, prior to ASIQ 12.0.4. Use CIS with IQ 12.0.4 and above. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 10-15 Loading Data Using the INSERT Command Inserting Directly from a Foreign Database ■ Example: INSERT INTO customer (customer_id, cust_type, ...) LOCATION prod.asedb SELECT customer_id, cust_type, ... FROM customer; COMMIT; ■ Insert data from the customer_id, cust_type, ... columns in the customer table in the database asedb.dba on the server prod, into the corresponding columns of the customer table in the current database This example inserts the same columns as the above example, but only for the rows in which the value of customer_id = 1234: INSERT INTO customer (customer_id, cust_type, ...) LOCATION prod.asedb SELECT customer_id, cust_type, ... FROM customer WHERE customer_id = 1234; COMMIT; Sybase connectivity libraries must be installed on your system, and the load library path environment variable must point to them. ■ 64-bit platforms must use Open Client 12 libraries to load from foreign data servers. ■ 32-bit platforms may use either Open Client 11 or Open Client 12. 10-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command Using CIS ■ CIS (Component Integration Services) allows you to access data on a foreign server ■ You construct local tables in a proxy database • The data resides on the foreign server ■ Currently, CIS is only available on NT for ASIQ ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 10-17 Loading Data Using the INSERT Command Summary ■ When using the INSERT statement, run DBISQL or the client application on the same machine. ■ There are two ways to use the INSERT command: INSERT from SELECT and INSERT VALUES. ■ Use INSERT from SELECT command when: • Loading data from the IQ Store or IQ Catalog Store. • Loading directly from ASE or other foreign data source using the LOCATION clause. ■ Use INSERT VALUES command when: • Loading data row-by-row. 10-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Loading Data Using the INSERT Command Lab 10: Loading Data Using the insert Command Exercise Overview Topics ■ ■ CREATE TABLE and CREATE INDEX commands (review from Module 6, "Creating Tables and Indexes") INSERT command Goals This lab introduces how to load data using the INSERT command. After completing this lab, you should be able to: ■ Use a script or Sybase Central to create a new table with indexes ■ Write a script to load the new table using the INSERT command from an existing table in the database General tasks ■ ■ ■ Lab setup ©2000 Sybase, Inc. ■ Use a script or Sybase Central to create a table called co_residential_customer. Use a script or Sybase Central to create indexes on the co_residential_customer table. Create a script to load co_residential_customer from the existing residential_customer table. This lab assumes that you have created the megaphone ASIQ database. You must have also created the residential_customer table and populated it with data. Administering Adaptive Server IQforthe Data Warehouse, Version 1.0 10-19 11 Using ASIQ Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Using ASIQ Module Overview This module introduces additional SQL statements and functions specific to ASIQ. Objectives After completing this module, you should be able to: ■ Write SQL statements using ASIQ-specific features ■ Use ASIQ functions in SQL statements ■ Export data to files ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11-1 Using ASIQ ASIQ SQL ■ Conforms to the ANSI SQL 89 standard ■ Has many additional features not commonly found in other SQL implementations ■ Supports several functions not in the ANSI SQL standard Details on these topics to follow. 1 1 -2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ Review: SELECT Statement Syntax: Examples to follow. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 1 -3 Using ASIQ SELECT Statement ■ Example 1: select type, avg(price) from titles group by type ■ Example 2: select stores.stor_id, qty, title_id, stor_name from salesdetail, stores where salesdetail.stor_id = stores.stor_id ■ Example 3: select distinct au_lname, state from authors where state = 'UT' (continued . . .) ■ ■ 1 1 -4 Refer to Introduction to SQL class materials. The above examples use the pubs2 database. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ SELECT Statement ■ Example 4 (SELECT INTO): declare @var1 char(40) select fname into @var1 from customer where cust_no = 1234 ■ Results: into@var1 Haskell ■ Example 5 (ROLLUP) select year, model, color, sum(sales) from sales_tab group by ROLLUP year, model, color ROLLUP ©2000 Sybase, Inc. The ROLLUP operator in the GROUP BY clause allows you to analyze subtotals using different levels of detail. It creates subtotals that roll up from a very detailed level to a Grand Total. Rollup requires an ordered list of grouping expressions with all the aggregate functions available to the GROUP BY clause (sum, avg, min, max). DISTINCT cannot be used with ROLLUP and ROLLUP cannot be used in a SELECT statement that is nested with INSERT, UPDATE, or DELETE. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 1 -5 Using ASIQ Module Map ■ ASIQ-Specific SQL Features • Joins • Expressions in Subqueries • IF Condition • CASE statement ■ ASIQ-Specific SQL Functions • Numeric • String • Date and Time • Datatype Conversion ■ Exporting Data Each of these topics is covered in the next few slides. 1 1 -6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ ASIQ-Specific SQL Features Joins ■ Syntax: ■ The FROM table list creates a result set consisting of all the columns from the tables specified Examples in the next few slides. JOIN Joins compare two or more tables by specifying a column from each and comparing the values in those columns row by row. INNER JOIN All matching rows in the component tables are in the result set. OUTER JOIN Joins that include all rows regardless of whether there is a matching row. LEFT OUTER JOIN Selects all rows from the first table that meet the statement's restrictions. The second table generates values if there is a match on the join condition. Otherwise, the second table generates NULL values. RIGHT OUTER JOIN Selects all rows from the second table that meet the statement's restrictions. The first table generates values if there is a match on the join condition. Otherwise, the first table generates NULL values. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11-7 Using ASIQ KEY JOIN ■ Allows key joins between tables based on foreign key relationships ■ Example: SELECT emp_lname, id, order_date FROM sales_order KEY JOIN employee is the same as: SELECT emp_lname, id, order_date FROM sales_order, employee WHERE sales_order.sales_rep = employee.emp_id ■ Must have FK and PK defined to use KEY JOIN Case sensitivity 11-8 By default, ASIQ databases are case-insensitive in their string comparison. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ NATURAL JOIN ■ Allows natural j oins between tables based on common column names ■ Example: SELECT emp_lname, dept_name FROM employee NATURAL JOIN department is the same as: SELECT emp_lname, dept_name FROM employee, department WHERE employee.dept_id = department.dept_id You should be careful when using join operators. The server will join columns that are not intended to match, thus producing unwanted results. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11 - 9 Using ASIQ OUTER JOIN ■ Example: SELECT emp_lname, dept_name FROM employee LEFT OUTER JOIN department is the same as: SELECT emp_lname, dept_name FROM employee, department WHERE employee.dept_id *= department.dept_id List all the employees and find the department names, if one exists. 11-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ Expressions in Subqueries ■ ASIQ allows expressions in subqueries • Example: SELECT customer_lname, customer_fname, ( SELECT product_name FROM product WHERE customer_id = customer.customer_id AND product_id = 123) FROM customer ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11-11 Using ASIQ IF Condition Syntax: IF condition . . . THEN expression ... [ ELSE expression END IF Example: IF SomeValue > AnotherValue THEN SET AnotherValue = SomeValue; END IF; Transt-SQL IF statement BEGIN...END 11-12 Here is an alternative to the ASIQ IF statement. IF expression . . . statement ... [ELSE [ IF expression ] statement ] ... Use BEGIN and END to group a set of statements into a single compound statement. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ CASE Statement ■ Syntax: CASE expression WHEN expression THEN expression [, [ELSE expression ] END ■ Example: SELECT (CASE gender WHEN 'F' THEN 'Ms. ' WHEN 'M' THEN 'Mr. ' END) as Title, lname FROM customer Results Titl Mr. e Mr. Ms. Ms. Mr. Alternative syntax CASE WHEN search-condition THEN expression [,...] [ELSE expression ] END lname Mollan Sharpe d Cates Jones Miller Example: SELECT (CASE WHEN gender='F' THEN 'Female Customer' WHEN customer_id > 10000 THEN 'New Customer' ELSE 'Regular Customer' END) as Type FROM customer ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11-13 Using ASIQ A Word on Quotes ■ Single quotes are used to indicate strings ■ Double quotes are used to indicate table or column names ■ Two single quotes are used to include a single quote inside a string 11-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ Module Map • ASIQ-Specific SQL Features • Joins • Expressions in Subqueries • IF Condition • CASE statement ■ ASIQ-Specific SQL Functions • Numeric • String • Date and Time • Data Type Conversion ■ Exporting Data ■ ■ ©2000 Sybase, Inc. Details on these topics to follow. The list of functions on the next several pages are not supported by ASE. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11-15 Using ASIQ ASIQ Numeric Functions "TRUNCATE" The double quotes are required because of the key word conflict with the TRUNCATE TABLE statement. ASE ASE has equivalent numeric functions. 11-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ ASIQ String Functions ASE ©2000 Sybase, Inc. ASE has equivalent string functions except for the ASIQ LOCATE function. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11-17 Using ASIQ ASIQ Date and Tme Functions ■ ASIQ provides two classes of date and time functions • One set is T-SQL compatible; use DATEADD, DATEDIFF, DATEPART, and GETDATE • The other is the ANSI standard set of functions ■ Example: SELECT days( date('1997-09-17'),2) ■ Result: 1997-09-19 00:00:00.000 See the ASIQ Reference Manual for a complete list of date and time functions. Examples SELECT today(*) = 1999-03-14 SELECT YMD(1992,15,1) = 'Mar 1 1993' SELECT DATEFORMAT('1999-01-01','Mmm Dd, yyyy' = Jan 1, 199 9 SELECT DATENAME(month, '1999/3/17') = March SELECT DAYNAME('1987/05/02') = Saturday 11-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ ■ ^ ASIQ Datatype Conversion Functions ■ CAST • Returns the value of the expression converted to the specified datatype ■ Syntax: CAST(expression AS data type) ■ Example: CAST('This is a long string' AS CHAR(10)) ■ Result: This is a Conversion functions The following functions are supported by both ASIQ and ASE: CONVERT (datatype, expression [ ,format-style] ) HEXTOINT (hexadecimal-string) INTTOHEX (integerexp) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11-19 Using ASIQ Additional ASIQ Functions 1 1 -2 0 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ Module Map • ASIQ-Specific SQL Features • Joins • Expressions in Subqueries • IF Condition • CASE statement • ASIQ-Specific SQL Functions • Numeric • String • Date and Time • Data Type Conversion ■ Exporting Data ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11-21 Using ASIQ Exporting Data from ASIQ ■ Two methods available • Redirection using ># with a SELECT statement A File size limit is 2GB • Data extraction using SET options with a SELECT statement A Fastest method of exporting data A File size limit is 128GB ■ Data extraction using SET options is new in v12.4.2 • Replaces OUTPUT TO command in earlier versions A OUTPUT TO is not supported in v 12.4.2 • Syntax to support this feature is temporary • Information on this feature is only contained in the Release Bulletin 11 - 22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ Exporting Data Using Redirection ■ Use the redirect symbol ># anywhere in a command to direct output to a file ■ Example: select * from employee ># empfile.txt ■ The file is placed relative to the directory where the session (DBISQL or ISQL) was started ■ Option to control the output on next page ... (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11 - 23 Using ASIQ Exporting Data Using Redirection Options Controlling the Output ■ Set Option OUTPUT_FORMAT = 'text' • Many file options available - See ASIQ Reference Manual, Chapter 5 ■ Set Option OUTPUT_LENGTH = 0 • Controls the length of fields • 0 is the default - No truncation of data ■ Set Option NULLS • Controls how NULLS are displayed/written ■ To redirect output and error messages, use >& filename ■ Append output to an existing file using >># or >>& • Will overwrite an existing file by default ■ For more information on exporting data using redirection, see the ASIQ Administration and Performance Guide. ■ Also, the ASIQ Reference Manual, Chapter 5, has the DBISQL options. 11 - 24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ Exporting Data Using Data Extraction ■ New feature to support high-volume data extraction • Currently limited to disk file or a named pipe ■ SET OPTION commands control extract behavior • Name of the file • Format: ASCII, binary, or binary swap • Column and row delimiters • NULL as zero (default is NULL) ■ Option names all begin with "Temp_" • To reflect this is a temporary implementation • Option names will be changed in a future release • Functionality will continue to be supported ■ String fields will be unquoted • No support currently for change to quoted strings ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11 - 25 Using ASIQ Options for Data Extraction ■ Set the name of the file • Set Option Temp_Extract_Name = '[path/]filename' A Path and file are relative to the ASIQ Server A Default is ’’, meaning standard output • Existing file will be overwritten ■ File Format - ASCII by default • Set Option Temp_Extract_Binary = 'ON' for binary • Set Option Temp_Extract_Swap = 'ON' for Binary Swap ■ Column Delimiter - Comma by default • Set Option Temp_Extract_Column_Delimiter = '|' (for example) (continued . . .) 11 - 26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ Options for Data Extraction ■ Row delimiter - newline by default • Set Option Temp_Extract_Row_Delimiter = return (for example) • Use appropriate delimiter from your database collation order ■ Nulls as Zero Option - OFF by default • Set Option Temp_Extract_Null_As_Zero = 'On' • If set will represent values as follows: ▲Arithmetic - 0 ▲" for character data A 1900-01-01 for dates A 00:00:00.000000 for times A 1900-01-01 00:00:00.000000 for timestamp datetime If you set an extract option, execute a SELECT statement, and then execute a second SELECT statement without changing the extract filename, the second file will overwrite the first file. There is no method for appending data to a file. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11 - 27 Using ASIQ Data Extraction ■ Example: Set Temporary Option Temp_Extract_Name = 'C:\data\customer.dat'; Select * from residential_customer; Set Temporary Option Temp_Extract_Name = ''; 11 - 28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Using ASIQ Summary ■ Review of SELECT statement ■ You can use ASIQ-specific SQL: • Key joins, natural joins, expressions in subqueries • IF condition, CASE statement ■ There are ASIQ-specific SQL functions for: • Numeric, string, date/time, datatype conversion ■ There are two methods to export data from ASIQ: • Redirection using ># • Data extraction using SET options ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 11 - 29 Using ASIQ Lab 11: Using ASIQ Exercise Overview Topics ■ ■ Goals This lab develops your SQL skills. After completing this lab, you should be able to: ■ Write SQL statements using ASIQ-specific features ■ Use ASIQ functions against the IQ database ■ Export data to a file General tasks Lab setup ■ Write a query using the NATURAL JOIN syntax. ■ Write a query using the CASE statement. ■ Write a query using the rowid function. ■ Export data using a SELECT statement ■ ■ 11 - 30 Writing SQL statements ASIQ functions This lab assumes that you have created the megaphone database and have created tables and indexes in that database. The data should be loaded in all the tables from Labs 8, 9, and 10. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 12 ASIQ Operational Data Administration Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Module Overview This module provides data administration topics relevant to the ASIQ environment. Objectives After completing this module, you should be able to: ■ Define a transaction and how it is implemented in ASIQ ■ Describe ASIQ's locking ■ Describe how data security is implemented through the use of users, groups, and permissions ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-1 ASIQ Operational Data Administration Module Map ■ Transactions ■ Locking ■ Snapshot Versioning ■ Security 1 2 -2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Transaction Processing ■ Allows many users to read from the database while it is being updated ■ ASIQ's approach to transaction processing is called snapshot versioning • Allows multiple readers and one writer per table • Further details to follow ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 2 -3 ASIQ Operational Data Administration What Is a Transaction? ■ A logical unit of work ■ Takes the database from one consistent state to another ■ All-or-nothing processing • Everything is committed or • Everything is rolled back ■ Most IQ transactions begin and end automatically based on the command issued • You can also issue explicit commands to begin or end a transaction See Chapter 8, "Transactions and Versioning," in Adaptive Server IQ Administration and Performance Guide for more information. 1 2 -4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Transaction Commands ■ BEGIN TRANSACTION • To begin a user-defined transaction BEGIN TRAN[SACTION] [transaction-name] ■ COMMIT • To make any changes to the database permanent COMMIT [work] ■ ROLLBACK • To undo any changes made since the last COMMIT or ROLLBACK ROLLBACK [work] (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 2 -5 ASIQ Operational Data Administration Transaction Commands ■ SAVEPOINT • To establish a savepoint within a current transaction SAVEPOINT [savepoint-name] ■ ROLLBACK TO SAVEPOINT • To cancel any changes made since a savepoint ROLLBACK TO SAVEPOINT [savepoint-name] ■ CHECKPOINT • Writes changes to disk CHECKPOINT (continued . . .) 12-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Transaction Commands WITH CHECKPOINT ON ■ During a delete or a load to a table, you should specify WITH CHECKPOINT ON ■ A checkpoint is issued after successful completion of the statement ■ Example: LOAD TABLE mytable (...) FROM ... QUOTES OFF ESCAPES OFF WITH CHECKPOINT ON; See Module 8, "Loading Data from Files," for more information on the LOAD TABLE command and WITH CHECKPOINT load-option. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 2 -7 ASIQ Operational Data Administration Chained and Unchained Transaction Modes ■ Chained • Do not need to specify an explicit BEGIN to start a transaction • Commits a transaction only when an explicit COMMIT is executed or the statement executed has an autocommit • This is the default mode for ASIQ • ANSI standard ■ Unchained • Must specify an explicit BEGIN to start a transaction • This is the default mode for ASE ■ Can control the mode by setting the CHAINED database option autocommit 12-8 The following is a partial list of commands that have an automatic commit. . ALTER . CREATE . DROP . GRANT . REVOKE Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Completing Transactions ■ DML is not automatically committed • DML operations include inserts, updates, deletes, and queries ■ During inserts, updates or deletes • If it does not finish, the entire transaction is rolled back • If the connection is lost, the transaction is rolled back • Need to specify a COMMIT ■ DDL is automatically committed • DDL operations include CREATE, DROP, and ALTER ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 2 -9 ASIQ Operational Data Administration Module Map • Transactions ■ Locking ■ Snapshot Versioning ■ Security 12-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Locking ■ Locking is handled automatically by ASIQ ■ When a table is locked, no other transaction can have write access • Can only have read access ■ Locking is based on: • Data manipulation language (DML) operations • Data definition language (DDL) operations ■ DDL with IQ Multiplex • You cannot perform DDL in Multiplex mode • You can make changes only in Simplex mode ■ ■ ©2000 Sybase, Inc. DML and DDL commands to follow. See Chapter 8 of Adaptive Server IQ Administration and Performance Guide for more information on locking. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-11 ASIQ Operational Data Administration Locks for DML ■ ASIQ permits one writer and multiple readers per table ■ Rules: • Reads do not block writes • Writes do not block reads ■ The first transaction to open a table in write mode gains access • The second write transaction receives an error DML examples 12-12 ■ INSERT... . . . . LOAD TABLE. DELETE... SELECT... UPDATE... Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Locks for DDL ■ DDL operations include CREATE, DROP, and ALTER • Lock out all other readers and writers ■ Rules: • Cannot start any DDL while any other transaction is using the table • Cannot start any DDL while other DDL commands are running • DDL commands are automatically committed DDL examples ■ . . . . . ©2000 Sybase, Inc. CREATE TABLE... ALTER TABLE... DROP TABLE... CREATE DB SPACE. DROPDBSPACE... CREATE INDEX... Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-13 ASIQ Operational Data Administration ANSI Isolation Levels ■ ANSI defines four isolation levels • Level 0 allows dirty reads • Level 1 prevents dirty reads • Level 2 ensures repeatable reads • Level 3 prevents phantom reads ■ When updating a table, ASIQ uses level 3 ■ ASIQ protects you from data inconsistencies by: • Ensuring only one user can modify a table at a given time • Keeping changes invisible to other users until the changes are complete • Maintaining time-stamped snapshots of data objects in use at any time Phantom reads 12-14 When a transaction begins, updates made by other transactions are invisible to it. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Module Map • Transactions • Locking ■ Snapshot Versioning ■ Security ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-15 ASIQ Operational Data Administration Snapshot Versioning ■ ASIQ's method of managing changes to a table ■ Also referred to as table-level versioning ■ Allows updates to tables while users are reading the data ■ Supports ANSI isolation level 3 12-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Versioning Level ■ To the user, the unit of versioning is at the table level • Internally, data is versioned at the page level ■ ASIQ assigns a version ID to each table • Each active version of a table resides on disk • The version ID is not accessible to users ■ For performance reasons, you may not want to write to multiple tables at the same time ■ ■ ©2000 Sybase, Inc. A complete copy of each table version would be very large. ASIQ conserves resources by allowing table versions to share pages that are not being updated. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-17 ASIQ Operational Data Administration Tabe Versioning How Does It Work? 1. Upon connection, users see committed tables • These are called table blockmaps 2. When a table is modified, new blockmaps are created for changed pages • The "old" blockmaps are retained by current users • When changes are committed to a table, the new blockmap becomes available 3. A user must issue an explicit COMMIT statement or exit the database and log back in to use the new blockmap • The old blockmaps are retained until all users are no longer using that blockmap commit Most query tools cannot issue a COMMIT statement. There is an ODBC option AUTOPRECOMMIT = ON that issues a COMMIT before every SELECT. Example to follow. 12-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Versioning Example ■ At t1, two users are in the database reading data from the customer, product, and order tables (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-19 ASIQ Operational Data Administration Versioning Example ■ At t2, a write user logs into the database and begins inserting into the customer table. The read users still see the original versions of the customer, order, and product tables. (continued . . .) 12-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Versioning Example At t3, the changes to the customer table are committed. The read users still see the original versions of the customer, ,order and product tables. (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-21 ASIQ Operational Data Administration Versioning Example At t4, a new read user logs in and sees the new version of the customer table as well as the order and product tables. Read users (continued . . .) 1 and 2 still do not see the new version of the customer table. 12-22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Versioning Example ■ At t5, read users 1 and 2 have issued a COMMIT or they have exited from the database and logged back on. All users see the new version of the customer table and the old version is gone. In IQ Multiplex, the new table version is replicated from the Catalog Store on the write server to the Catalog Stores on all reader servers. After the writer commits changes, the new version will be replicated and available to users on the reader servers in about 1 minute. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-23 ASIQ Operational Data Administration Option to COMMIT After Every SELECT ■ In Interactive SQL, select Command->Options, and then select After Every Command checkbox 12-24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration ODBC AutoPreCommit ■ Turn to ON to COMMIT before execution of a statement ■ Default for AutoPreCommit is OFF ■ Set in either the Windows registry or the .ini file ■ Example: AutoPreCommit=ON ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-25 ASIQ Operational Data Administration Snapshot Versioning: Issues ■ Version management does require some overhead, but the effect on performance is minimal in the Catalog Store • ASIQ Server performance may suffer from multiple table inserts/deletes ■ Disk space can become an issue • May need to increase your disk space in order to store overlapping versions ■ Data consistency between tables must be understood by all users 12 - 26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Module Map • Transactions • Locking • Snapshot Versioning ■ Security ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-27 ASIQ Operational Data Administration Data Security ■ ASIQ allows privacy of appropriate information within the database ■ Security is implemented at various levels: • Users • Groups • Object/command-level permissions 12 - 28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Users ■ You should set up individual user IDs for each user • Lets you tell which connects are which users ■ DBA (Database Administrator or database owner) has authority to add new users ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-29 ASIQ Operational Data Administration Users and Groups ■ User • A login can access a database ■ Groups • Enables a collective name for a set of users • Simplifies administration ■ Users in groups • SYS group • PUBLIC group 12 - 30 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Specal User DBA User ■ A user with Database Administrator (DBA) authority is the database administrator or database owner ■ May be granted or transferred to other users ■ Responsible for the overall management of the database • Adds new users and permissions • Authority to create database objects and assign ownership ■ Default password "SQL" ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-31 ASIQ Operational Data Administration Creating Users DBISQL ■ Syntax: GRANT CONNECT TO userid [,...] IDENTIFIED BY password [,...] ■ Example: GRANT CONNECT TO laura_smith IDENTIFIED BY secret; ■ To create a user with no password, type: GRANT CONNECT TO userid ■ 12 - 32 A user with no password cannot connect to the database. This user is useful when you are creating groups. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Creating Users with Sybase Central 1. Connect to the database 2. Click Users and Groups folder 3. Double-click Add User 4. Follow wizard (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-33 ASIQ Operational Data Administration Creating Users with Sybase Central ■ Click Finish 12-34 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Special Groups ■ SYS group • Owner of all system tables and views for the database • Automatically created, no password • Cannot connect to the database as SYS ■ PUBLIC group • Member of the SYS group with read access for some of the system tables and views • Any new user is automatically a member of the PUBLIC group • Automatically created with connect permissions to the database ■ Can use REVOKE to remove membership in these groups REVOKE ©2000 Sybase, Inc. Syntax to follow. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-35 ASIQ Operational Data Administration Creating Groups DBISQL ■ Syntax: GRANT GROUP TO userid ■ Allows the user to have members ■ Example: GRANT CONNECT TO marketing; GRANT GROUP TO marketing; This example creates a user (marketing) with no password. You can not connect to the database with the marketing user. Sybase Central 12-36 1. 2. 3. 4. Connect to the database. Click the Users and Groups folder. Double-click Add Group. Follow wizard. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Adding a User to a Group DBISQL ■ Syntax: GRANT MEMBERSHIP IN GROUP group-name TO userid ■ Example: GRANT MEMBERSHIP IN GROUP marketing TO laura_smith ■ Must have already granted connect permis sion to laura_smith Steps to create a user in 1. a group 2. 3. 4. ©2000 Sybase, Inc. GRANT CONNECT TO laura_smith; GRANT CONNECT TO marketing; GRANT GROUP TO marketing; GRANT MEMBERSHIP IN GROUP marketing TO laura_smith; Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-37 ASIQ Operational Data Administration Table and Vew Permissions Syntax: Example: There are several ways to grant user permissions in Sybase Central • See Chapter 10, "Managing User IDs and Permissions," in the Adaptive Server IQ Administration and Performance Guide. 12-38 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Stored Procedure Permissions ■ Must have EXECUTE permission to execute a stored procedure ■ Similar to granting permissions on tables and views ■ Example: GRANT EXECUTE ON my_procedure TO l aura_smith ■ Procedures execute with the permissions of their owners Inserts/deletes Any procedure that inserts or deletes from a table will execute successfully only if the owner of the procedures has the correct level of permissions. Therefore, the owner must have INSERT or DELETE permission on that table. Sybase Central You can grant user permissions on procedures in Sybase Central. See Chapter 10, "Managing User IDs and Permissions," in the Adaptive Server IQ Administration and Performance Guide. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-39 ASIQ Operational Data Administration REVOKE Statement ■ The REVOKE statement is the exact converse of the GRANT statement ■ Example: REVOKE 12 - 40 SELECT ON customer FROM laura smith Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Permissions Hierarchy ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-41 ASIQ Operational Data Administration Database Object Names and Prefixes ■ Every database object is an identifier; up until now, all database objects have been referred to using their simple names ■ Example: SELECT * from employee ■ Tables, procedures, and views all have an owner ■ Example: SELECT * from "DBA".employee ■ When referring to a database obect, you need a prefix unless: • You are the owner of the object • The database object is owned by a group ID of which you are a member To get around typing in 1. GRANT CONNECT TO sales; "DBA" 2. GRANT GROUP TO sales; 3. GRANT RESOURCE TO sales; 4. GRANT SELECT ON tablename to sales; 12 - 42 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Operational Data Administration Summary ■ Snapshot versioning is ASIQ's approach to transaction management. ■ Locking is handled automatically by ASIQ. • One writer and multiple readers at the table level ■ Keep data secure by controlling a user's access to the database and the objects within the database. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 12-43 ASIQ Operational Data Administration Lab 12: ASIQ Operational Data Administration Exercise Overview Topics ■ ■ ■ Goals This lab develops your DBA skills. After completing this lab, you should be able to: ■ Set up read-only users ■ See what happens when the database is being updated General tasks ■ Create a user using Sybase Central. ■ GRANT the appropriate permissions to the new user. ■ Update the residential_customer table in one window as the DBA user. ■ Query the residential_customer table in a separate window as the read-only user. Lab setup ■ ■ 12 - 44 Creating a user Granting permissions Snapshot versioning This lab assumes that you have created the megaphone database and have created tables and indexes in that database. The data should be loaded in all the tables from Labs 8, 9, and 10. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 13 Joins Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Joins Module Overview This module discusses ad-hoc oins and predefined join indexes. It also explores when and how to create an ASIQ join index. Objectives After completing this module, you should be able to: • Compare ad-hoc joins to join indexes • Create a join index • Synchronize a join index See Chapter 4, "Adaptive Server IQ Indexes," in the Adaptive Server IQ Administration and Performance Guide for additional information on join indexes. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 13-1 Joins Types of Joins ■ Ad-hoc joins • Joined at query time ■ Join index • An internal structure that relates table columns • Represents two or more tables, including inner, left outer, and right outer rows • May provide better performance than ad-hoc joins • Requires additional disk space and time to create 1 3 -2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Ad-Hoc Joins ■ A join merges rows from two tables into a result table ■ Six types of ad-hoc join algorithms • Nested loop • Hash • Sortmerge • Sort/merge push down • Nested loop push down • Hash push down ■ Additional join type called Cartesian nested loop • Joins without a join condition in the WHERE clause Nested loop ■ Takes a row from the larger table of the join and compares it to each row of the smaller table. ■ You want the rows from the smaller side of the join to stay in memory. Hash ■ Similar to nested loop, except the smaller side is "hashed" into an in-memory table with a hashing function applied to the join keys. ■ Requires fewer comparisons than a nested loop, but adds the cost of computing the hash key for each row on both sides of the join. Sort/merge Sort/merge ■ Sorts the rows on both sides and then compares the rows. push down ■ Bloom-filter based semijoin that significantly reduces the number of rows projected and the number of rows to be sorted. Nested loop push down ■ IQ turns the keys of the smaller side of the join into an IN list on the large table. Hash push down ■ Combination of a hash join and ASIQ's special index processing. Cartesian nested loop ■ A variation of the nested loop join. A many-to-many or Cartesian join will produce a row for every combination of rows from both sides. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-3 Joins When to Use Ad-Hoc Joins Instead of Join Indexes ■ Always try ad-hoc joins first before creating join indexes ■ If the ratio of data in oin tables is higher than 10 to 1 • For example, lookup tables • Ad-hoc joins recommended due to data explosion ■ For self-joins ■ For many-to-many relationships 1 3 -4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins When to Create a Join Index ■ After trying ad-hoc queries ■ If certain tables are typically joined together in queries ■ There is adequate disk space ■ Fairly static tables ■ Ratio of data in join index is less than 10 to 1 • This limit is due to high disk overload • Recommend a ratio of less than 5 to 1 for performance reasons ■ ■ ©2000 Sybase, Inc. The Adaptive Server IQ Administration and Performance Guide recommends the ratio of data to create a join index to be less than 10to1. For performance reasons, a ratio of less than 5 to 1 is preferred. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 3 -5 Joins Ad-Hoc Joins Versus Join Indexes ■ Join indexes can involve multiple tables and are subject to certain rules Even if extra build time is available and additional disk space is not an issue, join indexes cannot be created in all cases. Synchronizing 13-6 This topic is discussed in detail later in the module. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Creating a Join Index Step Overview ■ Step 1: Create the tables involved in the join index CREATE TABLE... ■ Step 2: Define the relationships ■ Step 3: Create the indexes for the tables being joined CREATE INDEX... ■ Step 4: Load the data into the tables LOAD TABLE... or INSERT... ■ Step 5: Create the join index CREATE JOIN INDEX... ■ Step 6: Synchronize join index, if required SYNCHRONIZE JOIN INDEX... ©2000 Sybase, Inc. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 13-7 Joins Step 1: Create Tables ■ Create the tables involved in the join index • CREATE TABLE command • Sybase Central ■ See Module 6, "Creating Tables and Indexes" ■ Example: The example in this module joins customer and product tables. You would also need to create the product table as part of step 1. 1 3 -8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Step 2: Define the Relationships ■ Must determine the relationships between each pair of tables ■ Types • One-to-many (ONE>>MANY) • Many-to-one (MANY>>ONE) • One-to-one (ONE>>ONE) One-to-many . ONE >>MANY ■ One row in one table potentially matches with one or more rows in another table. Many-to-one . MANY>>ONE ■ One or many rows in one table potentially match with one row in another table. One-to-one . ONE >>ONE ■ One row in the first table potentially matches with one row in the second table. ■ ©2000 Sybase, Inc. If the join relationship specified is incorrect, the extra rows are discarded and not included in the join index. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 3 -9 Joins Join Hierarchy ■ All ASIQ join relationships must have a join hierarchy • A tree that illustrates how all the tables in a join are connected • Determine the top table, which is always on the MANY side ■ Rules • A table can occur only once • A table can have only one arrow leaving it • All tables must be connected • An arrowhead represents the MANY side of a relationship Notes 13-10 In this example, Table C is the "top table." Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Types of Join Hierarchies ■ Linear joins • Each table is related to the table above it, until you reach the top table • Each pair of tables represents a one-to-many relationship ■ Star joins • Each table is related to one table in the middle • The table in the middle represents the MANY side, sometimes called the fact table • The ONE tables are called dimension tables ■ You can create join indexes or have ad-hoc joins for both linear and star joins ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-11 Joins Entity-Relationship Diagram ■ This example is used throughout this module In this entity-relationship diagram, a customer can have one or more orders. 13-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Join Hierarchy with the Top Table ■ order table is the "Top Table" order becomes the top table because it is on the MANY side of the relationship. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-13 Joins Creating a Join Index Step Overview • Step 1: Create the tables involved in the join index CREATE TABLE... • Step 2: Define the relationships ■ Step 3: Create the indexes for the tables being joined CREATE INDEX... ■ Step 4: Load the data into the tables LOAD TABLE... or INSERT... ■ Step 5: Create the join index CREATE JOIN INDEX... ■ Step 6: Synchronize the join index, if required SYNCHRONIZE JOIN INDEX ... 13-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Step 3: Create the Indexes ■ Create the column indexes for the tables being joined ■ Columns involved in oins must have an HG or LF index ■ Example: CREATE HG index customer_id_HG on customer(customer_id); CREATE LF index cust_type_LF on customer(cust_type); ■ To determine the index types for each column, see Module 5, "ASIQ Index Types and Data Types." ■ To create indexes on each column, see Module 6, "Creating Tables and Indexes." Remember to create all the indexes for the customer and order tables. Sybase Central ©2000 Sybase, Inc. ■ Indexes can be created either using the CREATE INDEX command or using Sybase Central. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-15 Joins Step 4: Load Data ■ Load the data into the tables • Can use LOAD TABLE or INSERT command • See Modules 8, 9, and 10 on data loading ■ Example: LOAD TABLE customer (customer_id '|' ) FROM ... You need to load or insert data into the order table also. 13-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Creating a Join Index Step Overview • Step 1: Create the tables involved in the join index CREATE TABLE... • Step 2: Define the relationships • Step 3: Create the indexes for the tables being joined CREATE INDEX... • Step 4: Load the data into the tables LOAD TABLE... or INSERT... ■ Step 5: Create the join index CREATE JOIN INDEX... ■ Step 6: Synchronize join index, if required SYNCHRONIZE JOIN INDEX... ©2000 Sybase, Inc. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 13-17 Joins Step 5: Create the Join Index ■ Must be DBA or the table owner and have RESOURCE authority to CREATE JOIN INDEX ■ Syntax: CREATE JOIN INDEX join-index-name FOR join-clause ■ Example: CREATE JOIN INDEX customer_order_join FOR customer FULL OUTER JOIN order ON customer.customer id = order.customer id (continued . . .) join-clause [ ( ] join-expression join-type join-expression [ on search-condition ] [ ) ] join-expression { table-name | join-clause } join-type [ NATURAL ] FULL [ OUTER ] JOIN Another example and further explanation follow later in this module. 13-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Step 5: Create the Join Index Specifying the Join Type ■ Join type is always FULL OUTER; OUTER keyword is optional ■ If you are joining equivalent columns with the same names, you specify NATURAL JOIN ■ If you are joining columns based on keys, you must have specified FOREIGN and PRIMARY keys ■ Use the ON clause to join equivalent values in two tables (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQforthe DataWarehouse, Version 1.0 13-19 Joins Step 5: Create the Join Index ■ Same example (natural oin): CREATE JOIN INDEX nat_customer_order_join FOR customer NATURAL FULL OUTER JOIN order ■ Join column names must be the same in the tables being joined (continued . . .) Keyjoin CREATE JOIN INDEX key_customer_order_join FOR customer FULL OUTER JOIN order ■ 13 - 20 Foreign and primary keys must be defined during the CREATE TABLE operation for customer and order tables in the above Key join example. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Step 5: Create the Join Index ■ Results: • When you create a join index, a message in the log appears: Sybase Central ©2000 Sybase, Inc. ■ ■ You can create a join index in Sybase Central. See Chapter 4 of the Adaptive Server IQ Administration and Performance Guide. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-21 Joins Creating a Join Index Step Overview • Step 1: Create the tables involved in the join index CREATE TABLE... • Step 2: Define the relationships • Step 3: Create the indexes for the tables being joined CREATE INDEX... • Step 4: Load the data into the tables LOAD TABLE... or INSERT... • Step 5: Create the join index CREATE JOIN INDEX... ■ Step 6: Synchronize join index, if required SYNCHRONIZE JOIN INDEX... 13 - 22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Step 6: Synchronize Join Indexes ■ This step ensures that the data is loaded in the correct order for the join ■ It automatically occurs when: • You create the join index • Changes are made to the top table of the join hierarchy ■ Otherwise, must be manually performed, which can be time-consuming • Schedule during off-peak hours • Synchronize after entire set of inserts and deletes (do not do after every insert or delete) (continued . . .) If you complete step 5 (CREATE JOIN INDEX) before step 4 (LOAD TABLE or INSERT), you do not have to synchronize the data for the initial setup. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-23 Joins Step 6: Synchronize Join Indexes ■ Syntax: SYNCHRONIZE JOIN INDEX [ join-index-name [, join-index-name] ■ If you omit the index name, ASIQ synchronizes all oin indexes • Because this process is so time consuming, it is best to specify joins and schedule them individually ■ Example: SYNCHRONIZE JOIN INDEX customer_order_join 13 - 24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Multiple-Table Join Example ■ Join hierarchy: ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-25 Joins To Create the Join Index CREATE JOIN INDEX cust_prod_order_join FOR customer FULL OUTER JOIN order ON customer.customer_id = order.customer_id FULL OUTER JOIN product ON order.product_id = product.product_id ■ If no key definitions exist, a ONE>>MANY is assumed left to right 13 - 26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Rules for Join Indexes Conditions and Restrictions ■ You must be Database Administrator or table owner ■ You can combine steps 1 and 2 by defining relationships when you create the table (define keys) ■ You need to synchronize after additional inserts/deletes unless you have updated the top table ■ This approach is not recommended for data ratios greater than 10 to 1 (less than 5 to 1 may provide more optimal performance) ■ Join indexes cannot be created on many-to-many relationships ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-27 Joins Estimating Join Index Size ■ Stored procedure syntax: sp_iqestjoin table1, #ofrows, table2, #ofrows [, relation] [, iq_page_size] ■ Estimates the space needed to create oin indexes ■ Example: sp_iqestjoin customer, 10000, order, 30000 ■ Run this procedure for each pair of tables being joined Default values 13 - 28 ■ ■ Relationship: one-to-many. IQ page size: 64KB. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Actual Join Index Size ■ Stored procedure syntax: sp_iqjoinindexsize (join-index-name) ■ Returns the total size of the index in bytes ■ Example: sp_iqjoinindexsize ©2000 Sybase, Inc. customer_order_join Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-29 Joins Dropping a Join Index ■ Syntax: DROP JOIN INDEX join-index-name ■ Example: DROP JOIN INDEX customer_order_join ■ You must first drop the join index before dropping an underlying table 13 - 30 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Data Modification in a Join Index ■ Always insert, update, or delete from the underlying tables, not from the join index ■ You cannot do partial-width inserts to tables that participate in a join index • Drop the join index, do the partial-width insert, and then recreate the join index • Do not forget to synchronize ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-31 Joins How Join Indexes Are Used ■ The SELECT statement determines whether a join index will be used • Determined by the FROM and WHERE clauses • Do not need to specify the join index name in a query ■ ASIQ can use the same join index to resolve a query that involves the full join relationship or a query that involves a contiguous subset ■ Queries that can be resolved • Entire relationship • AtoD • BtoD • DtoF • CtoE • EtoF • C to E to F ■ Example of a query that cannot be resolved using the join index: • EtoD 13-32 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Joins Summary ■ Try using ad-hoc joins first. ■ Create a join index if: • Ratio of data in join tables is less than 10 to 1 (recommend less than 5 to 1). • There are no many-to-many relationships. • Same tables are frequently joined together in queries. • There is adequate disk space. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 13-33 Joins Lab 13: Joins Exercise Overview Topics ■ Goals This lab develops your data-loading skills. At the end of this lab, you should be able to: ■ Estimate the size of a join index before loading ■ Create a join index ■ Synchronize a join index General tasks ■ Participate in an instructor-led question-and-answer session. ■ Use the sp_iqestjoin procedure to estimate the size required for a join index. ■ Create a join index. ■ Synchronize a join index. Lab setup ■ 13 - 34 Join indexes This lab assumes that you have created the megaphone database on an ASIQ Server. Tables need to be created in that database and should be fully populated. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 14 Monitoring and Troubleshooting Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Module Overview This module identifies techniques to monitor ASIQ databases. In addition, it describes how to use ASIQ utilities to monitor and troubleshoot. Objectives After completing this module, you should be able to: ■ Monitor an ASIQ database ■ Monitor performance using IQ UTILITIES ■ Troubleshoot problems For further information, see Chapter 13, "Monitoring and Tuning Performance," in Sybase Adaptive Server IQ Administration and Performance Guide. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-1 Monitoring and Troubleshooting Module Map ■ Monitoring • Monitoring Files • Monitoring Users • Monitoring Deletes/Loads/Inserts • Using System Stored Procedures • IQ UTILITIES • System Utilities ■ Troubleshooting • What do I do if...? 1 4 -2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Monitoring Users ■ To see the connected users, use Sybase Central ■ Double-click the Connected Users folder for the database • More information can be obtained by double-clicking the connection ID ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-3 Monitoring and Troubleshooting Monitoring Loads/Deletes/Inserts Look at insert, update and delete notification messages... 90000 Records, 8 Seconds Mem: 3 0mb/M31 Main Blks: U5872/4%, Buffers: U6392/L9 Temporary Blks: U11721/28%, Buffers: U3083/L169 Main I: L173970/P2725 O: D27387/P21574 C:D21400 Temporary I: L341295/P7229 O: D50851/P13638 C:D32200 100000 Records, 8 Seconds Mem: 3 0mb/M31 Main Blks: U7784/6%, Buffers: U6392/L9 Temporary Blks: U13677/33%, Buffers: U3121/L116 Main I: L179988/P2725 O: D28345/P22521 C:D20500 Temporary I: L351507/P7230 O: D53062/P14611 C:D30100 ■ Final notification message at the end of the output: 100000 records were inserted into 'customer'. Insert for 'customer', completed in 86 seconds. 100000 records inserted. Mem: 14mb/M31 Main Blks: U23932/19%, Buffers: U6393/L0 Temporary Blks: U41/0%, Buffers: U9/L1 Main I: L249754/P2778 O: D36672/P30625 C:D14900 Temporary I: L421871/P14378 O: D63112/P15701 C:D28000 ■ This information is in the .iqmsg file ■ See "Interpreting Notification Messages" in Chapter 5 of the SybaseAdaptiveServerIQAdministrationandPerformanceGuide 14-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Monitoring Loading Messages ■ Three phases of the loading process • Phase 1 - Read data from all files and write LF, HNG, and FP indexes • Phase 2 - Sort data for HG indexes; continue writing other indexes to disk • Phase 3 - Write HG indexes to disk ■ Notification messages are issued based on the NOTIFY frequency • Default 100,000 rows • NOTIFY can be changed using LOAD TABLE or INSERT command option • Can also be set using Set Option Notify_Modulus (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 4 -5 Monitoring and Troubleshooting Monitoring Loading Messages ■ During Phase 1, NOTIFY reports time required to READ data from the source • Reports current memory (IQ caches + Heap)/ Max memory used so far Mem: 3 0mb/M31 • Shows blocks in use and percentage of total, buffers in use and buffers locked Main: Blks: U5872/28% Buffers: U6392/L9 Temporary Blks: U13677/33% Buffers: U3121/ L116 • Reports logical and physical reads, buffer destruction and compression information Main I:L179988/P2725 O:D28345/P22521 C:20500 Temporary I:L351507/P7230 O:53061/P14611 C:30100 (continued . . .) 1 4 -6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Monitoring Load Messages ■ After Phase 1, you will see similar notification messages as load phases complete, including a final report at the end of the load • If NOTIFY is set high, you may not see a report until the load completes • If NOTIFY is set too low, you may be inundated with messages ■ See Chapter 5, ASIQ Administration and Performance Guide, for more information on the load notification messages ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-7 Monitoring and Troubleshooting Monitoring the Database Stored Procedures ■ Examples of each to follow (continued . . .) 14-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Monitoring the Database sp iqcheckdb ■ Checks database validity • Reads every database page from disk into memory ▲ This may take a long time to run!! • Verifies and repairs • Saves information until next sp_iqdbstatistics is issued ■ Upon successful completion, updates the free list to reflect true storage allocation • Does not update free list if errors are found ■ Example on next page The free list is a list of blocks on disk that are available. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 4 -9 Monitoring and Troubleshooting Monitoring the Database sp iqcheckdb ■ This is a partial list ■ The statistics marked with an asterisk are the key statistics to look for orphaned blocks • If you see a non-zero value for any of these statistics, your database probably has a serious consistency problem ■ Need to issue a checkpoint before running this stored procedure to get accurate results (continued . . .) 14-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting sp_iqcheckdb and dbcc_option ■ dbcc_option determines processing done by sp_iqcheckdb • Works in conjunction with server start option -iqdroplks A -iqdroplks is used to drop leaked blocks with certain dbcc_options ■ dbcc_option default = 0 • Checks every page and object in the database (may run long) • Gathers statistics and reports results • With -iqdroplks, updates the free list if no errors are detected by sp_iqcheckdb ■ Other dbcc_options on next page (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-11 Monitoring and Troubleshooting dbcc_opton ■ Other dbcc_option values • 1 - Checks all blockmaps (runs fast) A Checks for leaked blocks and reports findings only • 2 - Not used • 3 - Checks blockmaps (runs fast) A With -iqdroplks and no errors detected, will update the freelist • 4 - Checks all indexes in database and reports errors (continued . . .) 14-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting dbcc_opton • 5 - Extensive consistency check on all indexes and reports errors ▲ Runs long with many LF and HG indexes in database • 6 - Checks and repairs all indexes, report repairs performed • 7 - Extensive check and repair (if possible) on indexes A Reports corrections ▲ Runs long with many LF and HG indexes in database ■ See Chapter 2, ASIQ Troubleshooting and Error Messages Guide ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-13 Monitoring and Troubleshooting Monitoring the Database sp iqdbstatistics sp iqdbsize (continued . . .) 14-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Monitoring the Database sp iqstatus ■ Things to look for: see next page (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-15 Monitoring and Troubleshooting Monitoring the Database sp iqstatus ■ Main and Temporary IQ Blocks Used • If percentage is high, add space to either store ■ Old Versions • Shows number of old table versions in the database and space used • These versions will be dropped and space recovered when no longer referenced by active transactions ■ Active Txn Versions • Number of active write transactions and amount of data created and destroyed ■ See Chapter 1, ASIQ Troubleshooting and Error Messages Guide, for more information on sp_iqstatus 14-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Monitoring Buffer Caches IQ UTILITIES ■ Monitors the performance of the buffer caches ■ Collects statistics on the buffer cache's memory and I/O on ASIQ ■ Statistics are stored in a log file Syntax: IQ UTILITIES { MAIN | PRIVATE } INTO dummy_table_name START MONITOR 'monitor_options [...]' (continued . . .) MAIN Starts monitoring the main buffer cache for the IQ Store of the database to which you are connected. PRIVATE Starts monitoring the temp buffer cache for the Temporary Store of the database you are connected to. monitor_options -summary Displays summary information for both the main and temp buffer caches (default). -cache Displays activity in detail for the main or temp buffer cache. -cache_by_type Same results as -cache, but broken down by IQ page type. -io Displays detailed main or temp buffer cache I/O rates and compression ratios. -interval Specifies the reporting interval in seconds (default = 2 seconds). More monitor options continued on next page. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-17 Monitoring and Troubleshooting Monitoring Buffer Caches Examining and Saving Monitor Results ■ Results are stored in a text file called: • dbname.connection#-main-iqmon for main buffer cache results • dbname.connection#-temp-iqmon for temp buffer cache results ■ The text file may be named with a suffix specified in the monitor options (see below) ■ To see the results, use a text editor and display or print the file • File(s) will be created in same directory as .db file (continued . . .) dbname.connection# Represents your database name and the connection number. You can check the monitor output results using the UNIX command tail -f <name_of_file>. On NT, the file cannot be monitored while the process is running. You can check the monitor output results using the UNIX command tail -f <name_of_file>. On NT, the file cannot be monitored while the process is running. monitor_options (continued) -buffalloc - Displays information on the main or temp allocator. contention Displays many key buffer cache and memory manager locks. Displays information about processing threads. Specifies a -threads file suffix for the monitor output file. file suffix 14-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Monitoring Buffer Caches ■ Example: create table monitor_table (a varchar(1)); IQ UTILITIES PRIVATE INTO monitor_table START MONITOR '-summary -interval 20'; ■ First need to create a dummy table • IQ table only used for monitoring • The datatype for column a in the monitor _table can be a char(1) ■ Start the buffer cache monitor and record activity for the main and temp buffer caches (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-19 Monitoring and Troubleshooting Monitoring Buffer Caches ■ Example of the -summary option Sybase Adaptive Server IQ Performance Monitor ■ Users C = connected, A = Active ■ See Chapter 13, "Monitoring and Tuning Performance," in the Adaptive Server IQ Administration and Performance Guide for more information. 14-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Stopping the Buffer Cache Monitor ■ Syntax: IQ UTILITIES { MAIN | PRIVATE } INTO dummy_table_name STOP MONITOR ■ Example: IQ UTILITIES PRIVATE INTO monitor_table STOP MONITOR; ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-21 Monitoring and Troubleshooting System Utilities Monitor CPU Use and Paging ■ UNIX: • ps • vmstat • sar ■ NT: • Performance Monitor • Task Manager 14-22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Module Map • Monitoring • Monitoring Files • Monitoring Users • Monitoring Loads • Using System Stored Procedures • IQ UTILITIES • System Utilities ■ Troubleshooting • What do I do if...? See the Adaptive Server IQ Troubleshooting and Error Guide for a number of troubleshooting problems/scenarios and methodology to handle or correct problems. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-23 Monitoring and Troubleshooting Troubleshooting Fields What Do I Do If... ■ The ASIQ Server won't start? ■ A user cannot access a database? ■ The database fills during a load? ■ Processing slows down or hangs? 14-24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting ASIQ Server Won’t Start Possible Cause ■ May already be up! ■ Transaction log file does not match the database ■ Not using valid user ■ Environment variables are not set correctly ■ Network connections are not working ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-25 Monitoring and Troubleshooting User Cannot Access the Database or Database Objects ■ User may not have a valid user ID and/or password ■ The server was started with DBA use only ■ Database files may be missing ■ Data source is not correctly defined, ODBC ■ The database is in the process of being restored ■ User does not have correct permissions on database objects 14-26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Database Fills Up During the Load ■ ASIQ: • Suspends the load • Keeps checking to see whether another dbspace has been added ■ Allocate more space to the database • Use CREATE DBSPACE (syntax in notes) ■ Example of what to do: CREATE DBSPACE mydb_2 AS 'e:\\s2\data\mydb_2.iq' SIZE 200 CREATE DBSPACE dbspace-name AS filename ... [ {IQ STORE | IQ TEMPORARY STORE | CATALOG STORE }] . . . [ [SIZE] file-size ] Default Create a dbspace for the IQ Store. You can monitor the amount of space used in a database by looking at the load notification message. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-27 Monitoring and Troubleshooting Processing Slows Down or Hangs ■ Just one user, or several, or everyone? • If one user, what is the process? • If everyone, check the database or server ■ Look at paging to determine whether thrashing is a problem ■ Check buffer caches; they may be set too small • Be sure not to set IQ buffer cache sizes so that total memory requirements are exceeded ■ Look at query, check for correct indexes 14-28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Reporting Problems to Technical Support ■ Have ready: • Site ID • Environment information (platform and versions) A sp_iqstatus • Exact problem or query with error message ■ May need: • IQ Message Log, OS Error Log, Server Config File • stktrc.iq (stack trace file in same directory as .db file) ■ Determine: • Severity of problem • If problem is reproducible (DBISQL or ISQL or both) ■ See Chapter 2, ASIQ Troubleshooting and Error Guide, for the extensive checklist of things to do before contacting Technical Support ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-29 Monitoring and Troubleshooting Summary Good System Administrator Practices ■ Ensue tables have been created correctly, use IQ UNIQUE ■ Ensure index types have been chosen correctly ■ Set the correct values for memory ■ Perform the following on a regular basis: • Backups • Monitoring the logs • Monitor the space usage • Check performance Regular backups 14-30 See Module 16, "Backup and Restore," for more information. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Monitoring and Troubleshooting Lab 14 - Monitoring and Troubleshooting Exercise Overview Topics ■ Goals This lab explains how to use IQ UTILITIES monitoring tool. After completing this lab, you should be able to: . Start and stop IQ UTILITIES . View the log file created by IQ UTILITIES General tasks Lab setup ©2000 Sybase, Inc. IQ UTILITIES ■ Create a dummy table. ■ Start IQ UTILITIES. ■ Run queries in the megaphone database. ■ Look at the results. . Stop IQ UTILITIES. ■ This lab assumes that the ASIQ Server is up and running with the megaphone database loaded with data. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 14-31 15 Performance and Tuning Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Performance and Tuning Module Overview This module describes the IQ Query Engine and identifies performance tips for queries and updates. It also including information on how to read an IQ Query Plan. Objectives After completing this module, you should be able to: ■ Describe the IQ Query Engine ■ Define techniques to improve queries ■ Be able to read an IQ Query Plan ■ Define techniques to improve updates For more information on performance and tuning see Chapter 12, "Managing System Resources," in the Adaptive Server IQ Administration and Performance Guide. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 15-1 Performance and Tuning Module Map ■ Define the IQ Query Engine ■ Improving Query Performance • IQ Query Plan ■ Improving Update Performance 1 5 -2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Engine ■ Similarities with Traditional Query Engines • Once ASIQ has completed all the work it can in the indexes for each table, rows are projected and then joined or grouped in the same ways as in other query engines • Whenever multiple access paths (or operator algoritms) are available, then a cost-based decision must be made, often based on predicated selectivity estimates ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 5 -3 Performance and Tuning IQ Query Engine ■ Differences from Traditional Query Engines • Effects of most predicates local to a table can be combined with each other before any rows are actually projected from the table • Numerous query operators are available directly within the indexes, including: A Grouping and distincting ▲ Inter-column comparisons ■ Hash containment 1 5 -4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Engine Architecture Three Parts ■ IQ Server Front End • Includes parsing incoming statements, stored procedures, security checking ■ IQ Optimizer (more detail to follow) • Includes join optimization, index selection, subquery optimization and grouping algorithm selection ■ IQ Run-Time Engine • Includes the execution of predicates, joins, groupings and subqueries, as well as sorting ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-5 Performance and Tuning IQ Query Optimizer ■ Join Optimization • All possible join plans that avoid cartesian product joins are considered • Applicable oin indexes are considered • Join algorithms selection is done from: A Nested loop A Hash A Sortmerge A Sort/merge push down A Nested loop push down A Hash push down (continued . . .) ■ Nested loop ■ ■ Hash ■ Takes a row from the larger table of the join and compares it to each row of the smaller table. You want the rows from the smaller side of the join to stay in memory. Similar to nested loop, except the smaller side is "hashed" into an in-memory table with a hashing function applied to the join keys. Requires fewer comparisons than a nested loop, but adds the cost of computing the hash key for each row on both sides of the join. Sort/merge Sort/merge ■ Sorts the rows on both sides and then compares the rows. push down ■ Bloom-filter based semijoin that significantly reduces the number of rows projected and the number of rows to be sorted. Nested loop push down ■ IQ turns the keys of the smaller side of the join into an IN list on the large table. ■ Combination of a hash join and ASIQ's special index processing. Hash push down 15-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Optimizer ■ Index Selection • The optimizer does a cost-based selection of what order to execute predicates and which index to use for each predicate • The optimizer considers: ▲Predicate type ▲Indexes available on that column (or columns) ▲Estimated selectivity of this predicate ▲Estimated number of rows (continued . . .) Predicate ©2000 Sybase, Inc. A condition in the where clause which accesses only one table. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 5 -7 Performance and Tuning IQ Query Optimizer ■ Grouping Algorithm Selection • Three different algorithms are compared for each GROUP BY or DISTINCT operator A Sort-based A Hash-based ▲ Index-based (continued . . .) 1 5 -8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Optimizer ■ Subquery Optimization • Some EXISTS subqueries are flattened into distinct joins • Results of uncorrelated subqueries are used directly in the indexes of tables in the parent query blocks • Correlated subqueries ▲ Are migrated to minimize subquery re-executions A Have a 1-value result cache, and outer references are ordered to further minimize re-executions A Are optimized to maximize invariant operators ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 5 -9 Performance and Tuning Module Map • Define the IQ Query Engine ■ Improving Query Performance • IQ Query Plan ■ Improving Update Performance 15-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning Choosing Correct Index Types ■ To achieve the best performance, you must choose the correct indexes for your data ■ Review of index types Name Abbreviation Fast Projection FP Low Fast LF High Non Group HNG High Group HG ■ The optimized FP stores (FFP and FFFP) can reduce storage and improve some queries (continued . . .) Consider creating new tables with IQ UNIQUE and loading data from existing tables to take advantage of the optimized FP stores (FFP and FFFP). ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-11 Performance and Tuning Choosing Correct Index Types ■ ASIQ indexes are optimized according to the number of distinct values Unique Values Recommended Index Type < 1500 LF/HNG > = 1500 HG/HNG ■ LF and HG are the "fast" indexes that you should always use on any column used in a join, GROUP BY, or WHERE clause • They provide column cardinality to the optimizer ■ Use the UNIQUE or PRIMARY KEY constraint on any applicable column (continued . . .) Follow the algorithm outlined in Module 5, "ASIQ Index Types and Datatypes," to ensure you have chosen the correct index(es) for each column. UNIQUE or PRIMARY KEY 15-12 Use UNIQUE or PRIMARY KEY only on single columns. For HG indexes, no G-Array is constructed, thus reducing space and loading time. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning Choosing Correct Index Types ■ Recommended index types based on the query ■ These recommendations should not be your only criteria for picking an index • See Module 5, "ASIQ Index Types and Datatypes" ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-13 Performance and Tuning Database Options for Performance ■ Set option public.Force_No_Scroll_Cursors = 'On' • Off by default - buffer results set to permit scrolling of data • Better performance by setting to ON to turn off buffering ■ Set option public.OS_File_Cache_Buffering = 'Off • For NT and Solaris only • Turns off file system caching for these platforms (ON by default) • Has no effect on database stores built with raw devices 15-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Plans ■ IQ uses a Volcano style data-flow query engine • Queries are transformed into an upside-down tree of operator nodes, each of which can accept rows from any nodes immediately below it, and can pass rows up to the node above it • Each node transforms the row stream in some way, such as filtering some rows out, unioning or joining multiple row streams together, etc. • A 'Query Plan' is the textual display of a query tree ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-15 Performance and Tuning IQ Query Tree ■ A Query Tree consists of "nodes" • Each node represents a stage of work • Each node has a name and a number ■ Can be visualized as an upside down tree • Top of the tree is the root node • Lowest node is the leaf 15-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Plans ■ The Query: select colA, colB, colC from tableA, tableB where tableA.joincol = tableB.joincol group by groupcol ■ The Query Tree: ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-17 Performance and Tuning IQ Query Plans ■ Messages about queries, including join order and join algorithm • Output to dbname. iqmsg file • Default is OFF ■ Example: SET OPTION QUERY_PLAN = 'ON'; /* A look at customers who have the following */ /* service call waiting, caller id, and voice */ /* mail by fiscal period */ /* i.e. Q1,Q2,Q3,Q4 for year= 1998 */ select service_key,fiscal_period,count(*) from telco_facts T,month M where T.month_key=M.month_key and service_key = 4 group by fiscal_period,service_key order by fiscal_period,service_key ■ Results in IQ Message file: : Query Plan: :1 #07: Scrolling Cursor Store : Child Node 1: #05 : Output Vector: 3 entries (14 data bytes) :2 . #05: Order By : Child Node 1: #04 : Output Vector: 3 entries (14 data bytes) :3 . . #04: Group By (Hash) : Child Node 1: #03 : Output Vector: 3 entries (14 data bytes) :4 . . . #03: Join (Hash) : Left Child Node: #01 (continued . . .) 15-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Plans ■ Results (continued): : Right Child Node: #02: Valid Join Algorithms: NLJ, SMJ, SMPDJ, HJ, HPDJ : Left Input Table 1: telco_facts AS T : Right Input Table 1: month AS M : Join Result Constraint: Many to 1 : Condition 1: (T.month_key = M.month_key) : Output Vector: 2 entries (6 data bytes) :5 . . . . #01: Vertical Cursor : Table Name: T : Table Row Count: 1200000 : Condition 1 (Invariant): (T.service_key = 4) : Condition 1 Selectivity: 0.10000000 : Output Vector: 2 entries (8 data bytes) :5 . . . . #02: Vertical Cursor : Table Name: M : Table Row Count: 24 : Output Vector: 2 entries (6 data bytes) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-19 Performance and Tuning IQ Query Plans ■ Here is what the IQ Query Tree would look like for: select service_key,fiscal_period,count(*) from telco_facts T,month M where T.month_key=M.month_key and service_key = 4 group by fiscal_period,service_key order by fiscal_period,service_key 15-20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Plans ■ Query plans appear in the server log (.iqmsg) file • All user's query plans plus all other server messages are interleaved in the server log file • All plan lines in the server log are prefixed with the date, time connection id, and message number for query plan lines ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-21 Performance and Tuning IQ Query Plans ■ Other useful set options with query plan: • QUERY_DETAIL A Additional information, part of QUERY_PLAN • QUERY_NAME A Adds one line to the query plan with the name string supplied; makes it much easier to find your query plan in the server log file • QUERY_PLAN_AFTER_RUN A Delays query plan printing so that actual rows projected (and other information) can be included in the plan • QUERY_ROWS_RETURNED_LIMIT ▲ Limits the number of output rows from a query • NOEXEC A Generates the query plan but does not execute the plan 15 - 22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Plan Detail ■ QUERY_DETAIL • When turned ON, additional information is displayed as part of QUERY_PLAN • Output to dbname. iqmsg file • Default is OFF ■ Example: SET OPTION QUERY_PLAN = 'ON'; SET OPTION QUERY_DETAIL = 'ON'; select service_key,fiscal_period,count(*) from telco_facts T,month M where T.month_key=M.month_key and service_key = 4 group by fiscal_period,service_key order by fiscal_period,service_key; ■ Results in IQ Message file: ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-23 Performance and Tuning QUERY_ROWS_RETURNED_LIMIT ■ A query will be rejected if the estimated number of rows is greater than the value of this option ■ Default is 0, no row limit ■ Example: SET OPTION QUERY_ROWS_RETURNED_LIMIT = 10; Result set from query was > 10 15-24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning NOEXEC and ROWCOUNT Options NOEXEC ■ Does not execute the query plan ■ Example: SET OPTION NOEXEC = 'ON'; ROWCOUNT ■ Sets the number of rows to return to the users ■ Example: SET ROWCOUNT 10; ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-25 Performance and Tuning IQ Query Plan - Elements ■ All of the Nodes in the Query Plan have a Node Type • Leaf Node A One table or one join index • Join Node A One of the join types • Group By A One of the grouping operator's • Order By A Sort operator used by sort-merge joins, subquery outer reference ordering and sort-based grouping, as well as the ORDER BY clause • Vertical Grouping Cursor ▲ Leaf node where grouping is being done in the indexes (continued . . .) 15 - 26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Plan - Elements ■ Scrolling Cursor Store • Results cache that appear at the top of a query tree to support scrolling cursor access ■ Store • Results cache for invariant portions of correlated subqueries ■ Subquery • Executes correlated subqueries, or uncorrelated subqueries that could not be used directly with the parent query block indexes ■ Filter • Site of non-pushable non-join predicates ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-27 Performance and Tuning More Query Options Optimization Options ■ INDEX_PREFERENCE • Sets the index to use for query processing • This option will override the optimizer's index choice for testing purposes • Under most circumstances, it should not be changed ■ JOIN_OPTIMIZATION (default ON) • ASIQ optimizes the join order • If OFF, join order is determined by the order of tables ■ JOIN_MAX_HASH_ROWS (default 125,000 rows) • Sets the maximum estimated number of rows that the query optimizer will consider for a hash algorithm ■ MAX_CARTESIAN_RESULT (default 100,000,000 rows) • Limits the number of result rows from a Cartesian join ■ ROW_COUNTS (default OFF) • Specifies whether to count the number of rows in a query when it is opened ■ QUERY_TEMP_SPACE_LIMIT (default 2000MB) • Sets the maximum temp cache memory per user • Some queries may require more memory, set as needed Additional query optimization options 15 - 28 ■ There are additional options that can be adjusted. They are not listed because these options are designed primarily for internal Sybase use. ■ To see the complete list, see Chapter 12, "Managing System Resources," in the Adaptive Server IQ Administration and Performance Guide. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning IQ Query Performance Experimentation ■ The IQ Optimizer usually does a good ob of creating the query plan, but there will be times when you have a specific query that just runs too slow. Things you can try: • You can often influence the choice of algorithms by experimenting with the options: Join_Preference, Aggregation_Preference, and Index Preference • You can force the optimizer to accept your specified join order exactly by setting Join_Optimization off ©2000 Sybase, Inc. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 15-29 Performance and Tuning Module Map • Define the IQ Query Engine • Improving Query Performance • IQ Query Plan ■ Improving Update Performance 15 - 30 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning Loading Data from a Fixed-Length ASCII Flat File Fastest Way to Load Data ■ Try to achieve a parallel load by: • Specifying the ROW DELIMITED BY in the LOAD TABLE command • AND, data must be delimited and have a newline col 1 | col2 | col3 |\n For more information on this topic, see Module 8, "Loading Data from Files." ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-31 Performance and Tuning Using Disk Striping ■ You should use disk striping whenever possible ■ Allows you to spread data from a single file across multiple disk drives ■ Significant performance gains over traditional file management ■ Disk striping is on by default • Will place data in round-robin fashion on all disks • Do not use if you intend to drop any dbspaces Internal striping 15 - 32 Provided by ASIQ via SET OPTIONS; refer to the Adaptive Server IQ Administration and Performance Guide for more information. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning Using Multiple dbspaces ■ Create multiple dbspaces for your IQMain Store and IQ Temporary Store data ■ These files can be spread across multiple disks ■ Use CREATE DBSPACE command CREATE DBSPACE dbspace-name AS filename ... [ { IQ STORE | IQ TEMPORARY STORE | CATALOG STORE } ... [ [SIZE] file-size ] See Module 6, "Creating Tables and Indexes," for more information on the CREATE DBSPACE command. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-33 Performance and Tuning Spreading Access Across Separate Disks Place the data staging area on separate disks from the IQ Store, Catalog Store, and IQ Temporary Store 15-34 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning Improving INSERT/UPDATE/DELETE Performance ■ Ensure you have some working space in your IQ Main Store ■ Also, ensure you have adequate room in the IQ Temporary Store ■ INSERT, UPDATE, DELETE, and SYNCHRONIZE commands need extra space ■ Certain deletions require a large amount of work space • HG indexes require temp cache for sorting • Make temp cache as large as possible to avoid paging to disk ■ After deleting data for faster incremental loading, you can avoid backfilling empty rows using APPEND_LOAD database option • Applies to LOAD TABLE or INSERT commands • This leaves unused row IDs in tables ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-35 Performance and Tuning Memory Allocation Queries and Updates ■ Calculate total memory available for cache sizes • Adjust main and temp caches accordingly; usually set once • If the database is not being used, you can adjust caches for different operations • Do not overallocate physical memory ■ Keep I/O to a minimum • Use large buffer caches, if available ■ Monitor memory usage during loads and queries ■ Running out of memory results in excess swapping (continued . . .) Monitoring swap ■ ■ ■ UNIX VMSTAT command. UNIX SAR command. Windows NT Task Manager. For more information on configuring memory, see Module 7, "ASIQ Memory Configuration." 15 - 36 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning Memory Allocation Semaphores ■ In UNIX, if an ASIQ Server has an abnormal exit or a user has an ungraceful termination from an IQ session, a semaphore may be left behind in shared memory ■ To eliminate unneeded semaphores, you should run the ipcs command ■ Identify shared memory segments and semaphores that have a very old create date but have not been recently used with the ipcs -a command ■ Use the ipcrm with -m parameter to specify the memory segment ID and the -s parameter to specify the semaphore ID number ■ Example: % ipcrm -m mid1 -m mid2 ... -s sid1 -s sid2 ... Abnormal exit ©2000 Sybase, Inc. Killing processes may also result in semaphores or shared memory being left behind. Under normal circumstances, semaphores and shared memory segments are cleaned up automatically. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-37 Performance and Tuning Limiting Number of Active Queries on the IQ Server ■ The server startup parameter -iqgovern limits the number of queries executing concurrently • Default = (2 x number of CPUs) + 10 • Use this option to optimize memory usage, especially on servers with many CPUs and limited memory 15 - 38 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Performance and Tuning Summary ■ To improve query performance: • Use a sensible schema design. • Follow the recommendations for where to create indexes and what types to create. • Define the IQ UNIQUE attribues on all columns < 10000. ■ To improve load performance: • Load from a flat file, in parallel, if possible. • Use disk striping. • Use multiple dbspaces. • Spread access across disks. ■ Ensure that memory is allocated correctly. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 15-39 Performance and Tuning Lab 15: Performance and Tuning Exercise Overview Topics ■ ■ Goals General tasks Lab setup 15 - 40 SET OPTION QUERY_PLAN Query Trees This lab explains how to use the QUERY_PLAN option. After completing this lab, you should be able to: ■ View a query plan ■ Draw the Query Tree ■ Set the QUERY PLAN option to ON. ■ Run a query. ■ Look at the results in the IQ Message Log. ■ Draw the query tree. ■ This lab assumes that the ASIQ Server is up and running with the megaphone database loaded with data. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 16 Backup and Restore Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Backup and Restore Module Overview This module discusses backup and restore procedures for ASIQ databases. Objectives After completing this module, you should be able to: ■ Back up ASIQ databases ■ Restore ASIQ databases ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-1 Backup and Restore Backup Features ■ Three types of online database backup: • Full • Incremental • Incremental-since-full ■ Use multiple drives for backups, allowing parallel backups ■ Can run concurrently with other database operations, except metadata changes ■ Process backs up committed data Full backup Copies a complete copy of the database. Incremental backup Copies all transactions since the last backup of any type. Incremental-sincefull backup Copies all transactions since the last full backup. Committed data A backup begins with an automatic checkpoint. All data that is not committed when this checkpoint occurs is not included in the backup. 16-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Archive Devices ■ The archive device can be either disk or a magnetic tape drive ■ Disk backups must go to file systems, not raw devices ■ Supported tape devices • Digital linear tape (DLT) on UNIX • 4mm DDS • 8mm ■ Stacker drives with multiple tapes ■ ©2000 Sybase, Inc. BACKUP does not support: • Fixed-length tape drives on UNIX systems, such as quarter inch cartridge (QIC) drives. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 6 -3 Backup and Restore Backup ■ First the Catalog Store is backed up for a database and then the IQ Store Temporary data 16-4 The IQ Temporary Store is not backed up. However, the metadata and any other information needed to recreate the Temporary IQ Store is backed up. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Types of Backups ■ Full • Full backup of Catalog Store • Full backup of IQ Store • Default action ■ Incremental • Full backup of Catalog Store • Backs up changes to IQ Store since last IQ backup of any type ■ Incremental-since-full • Full backup of Catalog Store • Backs up changes to IQ Store since last full IQ backup Transaction Log ©2000 Sybase, Inc. The Catalog Server Transaction Log file is used for recovery purposes. This log is not used to restore the database, recover committed IQ transactions, or restore the Catalog Store. The restore program does check for existence of the log: ■ Full restore - The log must not exist. It must be deleted (or renamed or moved) before starting. ■ Incremental restore - The log must exist. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-5 Backup and Restore Running a Backup ■ Attended • Operator must be present • Prompts to mount archive media • Default action ■ Unattended • No prompts are issued • You must make appropriate size estimates and set up devices in advance 16-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore BACKUP DATABASE Syntax BACKUP DATABASE ... [CRC ON | OFF] ... [ATTENDED ON | OFF] ... [BLOCK FACTOR integer] ... [{FULL|INCREMENTAL|INCREMENTAL SINCE FULL}] ...TO 'archive_device' [SIZE #_of_KB] [ STACKER #_of_tapes_in_stack] ... [WITH COMMENT 'string'] ■ CRC - Sets 32-bit cyclical redundancy checking to ON ■ BLOCK FACTOR - Number of blocks to write at a time CRC ■ ■ BLOCK FACTOR The default is 25. SIZE & STACKER These options are discussed in the following slides. ©2000 Sybase, Inc. Activates 32-bit cyclical redundancy checking on a per-block basis. Used during a backup and automatically verified during a restore, affecting performance on both commands. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-7 Backup and Restore Example: Simple Backup ■ UNIX example: BACKUP DATABASE TO '/dev/rmt/0n' ■ Makes a full backup of the database to one tape device ■ The Catalog Store is backed up first, then the IQ Main Store 1 6 -8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore SIZE and STACKER Options ■ SIZE (KB) • Maximum size of the backed up data on that stripe • Should specify for unattended tape backups on platforms that do not reliably detect the end-of-tape marker • Should also specify whether backup from disk is not the default of 2GB ■ STACKER • Indicates that you are backing up to an automatically loaded multitape stacker device • Specify the number of tapes in that device Do not specify SIZE or STACKER if you are using a third-party backup product, because size information is conveyed in the vendor_specific_information string. To specify this string, see the section "Performance Backups with Non-Sybase Products," in the Adaptive Server IQ Administration and Performance Guide. The value of SIZE must be a multiple of 64. If you specify a SIZE that is not a multiple of 64, it will automatically be rounded up to a multiple of 64. If SIZE is not specified it is automatically set to 1.5GB. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 6 -9 Backup and Restore Example: Incremental Backup ■ UNIX example: BACKUP DATABASE INCREMENTAL TO '/dev/rmt/0n' SIZE 150 WITH COMMENT 'March 17 incremental backup of mydb database' 16-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Backup: Notes and Restrictions ■ You need Database Administrator privileges to run a backup ■ ASIQ does not rewind tapes before using them ■ After a backup, label each archive device ■ System-level backups are not adequate • A restore from a system-level backup could cause data loss or corruption ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-11 Backup and Restore Validating Your Database ■ Should run sp_iqcheckdb to make sure the database is in a usable state • Example on next page ■ Reads every database page from disk into memory and does various consistency checks ■ Statistics displayed on the IQ Store followed by the Temporary Store ■ Can take a long time on large databases This stored procedure consumes most of the database server's time. Run during nonpeak hours. Do not run sp_iqcheckdb while another user is doing inserts and deletes. Results may be misleading. sp_iqcheckdb can falsely report leaked blocks if there are multiple versions of any given table. 16-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore sp_iqcheckdb ■ Key statistics to look for are the orphaned blocks • These statistics have an asterisk next to them • If there is a non-zero value for any of these statistics, your database probably has a serious consistency problem • To get accurate results, run a checkpoint first ■ Partial results: ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-13 Backup and Restore Restore Features ■ Allows parallel restore using multiple tape drives ■ Can restore full database ■ Can restore from incremental database backup ■ Can restore to a new location • Useful for a lost device 16-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Before You Restore... ■ You must have Database Administrator privileges ■ You must be connected to the utility_db database ■ No user can be connected to the database being restored ■ For a full restore, the Catalog Store and the Catalog Transaction Log (.db and .log files) must not exist ■ For an incremental restore, the Catalog Store and the Transaction Log must exist To ensure exclusive access, start the database server with the -gd Database Administrator option set, but do not start the database you are restoring. utility_db To connect to the utility database: ■ From the command prompt, use the following command: asiqsrv12 -n mydb ■ ■ This command starts the database server but does not load a database— in this case, mydb. In Interactive SQL, select utility_db as the database name when you connect. The user ID and password are DBA and SQL, respectively. Catalog Store This is the DB file. This Catalog Transaction Log is the LOG file. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-15 Backup and Restore Restore Database ■ Syntax: RESTORE DATABASE 'db_file' FROM 'archive_device'[FROM archive_device] ... [RENAME dbspace_name TO 'new_dbspace_path']... ... [CATALOG ONLY] ■ db_file • Relative or absolute path ■ CATALOG ONLY option • Displays the header information only for the database dump ■ RENAME option • Specifies which files to restore and to which dbspaces • Cannot rename the transaction log using this option When you rename or move all other files in the database, it is preferable to rename the log file. To move or rename the log file, use the DBLOG utility. 16-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Restore Database: Full Restore ■ NT example: RESTORE DATABASE 'mydb.db' FROM 'C:\\asiq\\backup1' FROM 'C:\\asiq\\backup2' ■ The mydb database is restored from two disk files ■ All database files will be restored to their original locations ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-17 Backup and Restore Moving Database Files Two Methods ■ To move the database file that holds the Catalog Store (by default, the DB file), specify the new name as db_file m Example: RESTORE DATABASE 'c:\\newdir\\mydbnew.db' FROM 'C:\\asiq\\backup1' FROM 'C:\\asiq\\backup2' ■ For any other database file, use the RENAME option • See example on next foil (continued . . .) 16-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Moving Database Files ■ Example: RESTORE DATABASE 'salesdb.db' FROM '/dev/rmt/0n' RENAME '/s1/salesdb.1' TO '/s2/salesdb.1' ■ Useful if one or more dbspaces are lost due to disk failure Example ©2000 Sybase, Inc. This example restores the file /s1/salesdb.1 to a new location /s2/salesdb.1 and the file /s1/salesdb.2 to the same location. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-19 Backup and Restore Restore Database Displaying Header Information ■ Example: RESTORE DATABASE 'salesdb.db' FROM '/dev/rmt/0n' CATALOG ONLY ■ This option displays only the header information for the database and does not restore any data 16 - 20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Restore Database: Notes and Restrictions ■ You must restore full and incremental backups in the correct order ■ If the database is corrupt or if you are moving files, you must restore a full backup ■ To ensure tapes have been restored correctly, run sp_iqcheckdb ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-21 Backup and Restore ASIQ Backup and Restore Performance ■ Multiple tape drives provide the best performance ■ Set CRC OFF in the BACKUP command to improve the speed of backup and restore ■ Increase memory during backup • Adjust BLOCK FACTOR ■ Keep the size of the Catalog Store small • Creating non-IQ tables in it will increase backup and restore time ASIQ data is already in a compressed format. Hardware compression adds little in the way of performance or additional capacity. 16 - 22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Estimating Dump Size ■ ASIQ backs up compressed data (no zeros) ■ sp_iqstatus • Main IQ Blocks Used output gives size of compressed data ■ Use 11880 (Main IQ Blocks Used) * 4096 (Block Size in bytes) = Total Bytes ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-23 Backup and Restore DBLOG Utility ■ Should run this utility after: • Using RESTORE with a new database name • Using RESTORE with RENAME ■ Allows you to display or change the name of the Transaction Log or mirror associated with the database ■ Syntax: dblog [switches] database-file ■ Switches • -m mirror-name - Set transaction log mirror name • -l log-name - Set the transaction log name 16 - 24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Option for Backing Up a Large Database ■ Some databases may be too large to ever back up ■ Consider alternatives • Archive the source data for reloading • Use IQ Data Extraction utilities to selectively extract data ▲ Limit output to WHERE clauses A Take periodic "pictures" of tables and archive ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 16-25 Backup and Restore Summary ■ Determine a data backup and recovery strategy. ■ Schedule routine backups. ■ Mix full and incremental backups. ■ Test restores on a periodic basis. ■ Use sp_iqcheckdb to validate the database before a backup and after a restore. 16 - 26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Backup and Restore Lab 16: Backup and Restore Exercise Overview Topics ■ BACKUP DATABASE statement ■ Connecting to the utility_db ■ RESTORE DATABASE statement ■ sp_iqcheckdb stored procedure Goals This lab explains how to back up and restore data from ASIQ. After completing this lab, you should be able to: ■ Back up an ASIQ database to file ■ Connect to the utility database ■ Restore an ASIQ database from file General tasks Lab setup ©2000 Sybase, Inc. ■ Back up the megaphone database to file. ■ Disconnect from the megaphone database. ■ Rename the Catalog Store and Transaction Log files for a full restore. ■ Start the server using the utility_db database. ■ Reload the megaphone database from file. ■ Run sp_iqcheckdb to ensure the database is in a usable state. ■ This lab assumes that you have created the megaphone database and have created all the tables and indexes in that database. Data should be loaded into the database. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 16-27 17 Multiplexing Overview Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Multiplexing Overview Module Overview This is an introduction module for ASIQ multiplexing Objectives After completing this module, you should be able to: ■ Explain the features of ASIQ multiplexing ■ Understand the architecture and terminology for ASIQ multiplexing ©2000 Sybase, Inc. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 17-1 Multiplexing Overview What Is IQ Multiplexing? ■ An IQ multiplex consists of: • A number of nodes, each running ASIQ • A shared disk subsystem connected to all nodes • One node designated as the writer server • Other nodes designated as query server ■ Extends the speed, flexibility, and low cost of ownership of ASIQ to a multinode configuration ■ Extends support to multiterabyte databases, many billions of rows, and hundreds of simultaneous queries with high availability 1 7 -2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplexing Overview Multiplex Architecture Nodes ■ ■ ■ ■ ©2000 Sybase, Inc. Individual nodes can be different configurations (CPUs, memory, disk). Must be all UNIX or NT, can not mix. Can have up to 120 nodes. One write server that performs updates. The IQ Store must be on a raw device. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 17-3 Multiplexing Overview Multiplex Features ■ Data is shared among nodes ■ Each IQ node has its own local Temporary and Catalog Store ■ All data is stored in the shared IQ database, which is typically on a fiber channel ■ Could have multiple instances of IQ on one node without a fiber channel ■ 95% performance scaling ■ SMP-like management and tuning (continued . . .) 17-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplexing Overview Multiplex Features ■ No interruption in database if node crashes ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 17-5 Multiplexing Overview ASIQ Architecture (Simplex) Review ■ An ASIQ database consists of three main components: IQ Store Contains the IQ data as well as the database transaction log. Catalog Store Contains table definitions, system tables, and stored procedures. IQ Temporary Store 17-6 Contains temporary tables generated by certain queries. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplexing Overview ASIQ Architecture (Multiplex) ■ Each server has its own IQ Temp Store and Catalog Store and shares the IQ Main Store ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 17-7 Multiplexing Overview Write and Query Servers ■ Write Server • There is only one in an ASIQ Multiplex configuration • Handles all loading or updates to the database while queries are submitted • Can be used as Reader ■ Query Server • Read-only servers submitting queries • Also know as Read or Reader Server One Write Server 17-8 By allowing a single write server, the overhead and scalability limits of a distributed lock manager is eliminated. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplexing Overview Communication between Servers ■ The IQ Catalog Store data is copied from the Write Server to the Reader Servers ■ This is done though a process called Synchronization, further discussion to follow ■ SQL Remote is the data-replication technology shipped as part of ASIQ ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 17 -9 Multiplexing Overview Multplex Operating Modes Two Modes ■ Normal • Readers may acces new versions of tables as soon as they are available • Use this for best performance and availability ■ Strict • Maintains a "single version of the truth" • Readers will not have access to the new versions until all readers have access to a new version 17-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplexing Overview IQM Advantages ■ Scalability is unlimited ■ Start small, easy to grow ■ Can handle hundreds to thousands of concurrent queries ■ High availability ■ No need for extensive training ■ Low cost of ownership • Data compression • Low maintenance • No ongoing tuning of databases ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 17-11 Multiplexing Overview Summary ■ Use an IQ multiplex if you want to: • Scale query performance past limits of one node. • Match I/O to CPU capabilities. • Have high availability. ■ You can start small and add more nodes. 17-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplexing Overview Lab 17: Multiplexing Overview Exercise Overview Topics ■ Multiplex Architecture ■ Write Server vs Query Server ■ Strict vs Normal Mode ■ Features ■ Advantages Goal After completing this lab, you should be able to: ■ Explain the basic principles of ASIQ Multiplexing General tasks You will take a written quiz. Lab setup No lab setup is required. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 17-13 18 ASIQ Multiplex Hardware Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. ASIQ Multiplex Hardware Module Overview This module describes hardware storage for ASIQ multiplex. Objectives After completing this module, you should be able to: ■ Understand storage basics ■ Identify the correct hardware needs for ASIQ multiplex ©2000 Sybase, Inc. Administering Adaptive Server IQ for the DataWarehouse, Version 1.0 18-1 ASIQ Multiplex Hardware Module Map ■ Storage Overview • Storage Basics • RAID Basics ■ Configuring Storage 18-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Multiplex Hardware Storage Basics ■ Disks are getting bigger and faster ■ Common disk sizes are 9GB, 18GB, 36GB and 72GB ■ Common rotation speeds are 7200 rpm and 18,000 rpm ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 8 -3 ASIQ Multiplex Hardware RAID Basics ■ Redundant Array of Inter-connected Disks (RAID) ■ RAID Controller performs many functions: • Connects and manages many disks • Presents many disks as ONE or MORE larger "virtual" devices • Performs performance optimizations • Improves reliability • Other functions: Remote mirroring, snapshoting, mirror management, etc ■ All those functions are invisible to host I/O system ■ ■ 1 8 -4 RAID "mimics" and behaves like a single device. Hosts can NOT tell a difference between a RAID and "genuine" disk. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Multiplex Hardware RAID Diagram ■ Host computer only communicates with RAID Controller RAID Controller handles individual disk I/O and is transparent to host. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 18-5 ASIQ Multiplex Hardware RAID Levels ■ RAID Controller improves reliability by adding parity or even mirroring data inside a given "virtual" device ■ There are variations called RAID-level: • RAID0: Striping • RAID1: Mirroring • RAID0+1: Striping + Mirroring • RAID5: Parity • RAID-S: EMC variant of RAID5 1 8 -6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Multiplex Hardware RAID Striping ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 18-7 ASIQ Multiplex Hardware RAID Connectivity ■ Raid Controller connect to host system using various connections • Most common are SCSI, Fibre Channel (FC), ESCON and SSA 1 8 -8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Multiplex Hardware Module Map • Storage Overview A Storage Basics A RAID Basics ■ Configuring Storage ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 8 -9 ASIQ Multiplex Hardware Configuring Storage ■ Shared disk storage is the foundation for IQ Multiplex, along with: • Top Level Shared Directory • Shared IQ Main Store ■ IQM is based on multiple nodes being able to physically access shared storage devices ■ Recommend shared storage configuration with one or more Fiber Channel connected RAID Controllers connected as RAW devices to all nodes (hosts) in IQ Multiplex IQM would not perform as well in an NFS, NAS, or network drive environment. Even a cluster file system (available on some platforms) would perform poorly in an IQM environment. 18-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Multiplex Hardware IQM and Shared Disk Farm ■ Raw devices on for IQ Store ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 18-11 ASIQ Multiplex Hardware IQ Multiplex Hardware... Putting it together 18-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. ASIQ Multiplex Hardware Summary ■ Multiplexing takes advantage of a shared disk subsystem connected with fiber channel ■ Additional CPU power and memory space for processing queries is gained when attaching more systems to the shared disk array ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 18-13 ASIQ Multiplex Hardware There is no lab for this module. 18-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. 19 Creating a Multiplex Database Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Module Overview This module outlines the steps to set up a multiplex environment using Sybase Central from scratch Objectives After completing this module, you should be able to: ■ Create a Write Server ■ Create a Query Server ■ Create Temp Stores ■ Synchronize ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-1 Creating a Multiplex Database Steps to Set up Multiplex 1. Create the IQ Write Server 2. Create Query Servers 3. Synchronize 4. Add Temp Store for Writer 5. Add Main IQ Store dbspaces 6. Add Temp Store for Query Server The final steps are to create DDL and load data. 1 9 -2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Step 1 - Create the Write Server ■ Using Sybase Central, open up Utilities Folder ■ Run Create Muliplex Wizard ■ Enter appropriate information for: • Host Name • Shared Top Level File System Directory • Device for the IQ Main Store • Name for the IQ Write Server • Port number • Database name ■ Screen shots on next few pages (continued . . .) Before you start the wizard you need: • A shared directory with space for multiplex control information. Approx. 30MB per node is required. • Shared raw device(s) for the IQ Main Store. Typically a fiber channel disk array. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 9 -3 Creating a Multiplex Database Create the IQ Write Server Open the Utilities Folder 1 9 -4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Create the IQ Write Server Run the Create Multiplex Wizard • Enter the Host Name for the Write Server ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 9 -5 Creating a Multiplex Database Create the IQ Writer Server ■ Specify the shared top level directory and the initial raw device for the IQ Main Store 1 9 -6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Create the IQ Writer Server ■ Name the Write Server (MPXServer01 is the default) ■ Specify a name for the IQ Catalog Store ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-7 Creating a Multiplex Database Create the IQ Writer Server ■ Do not specify size since the device is raw (not accessible) ■ Use the default IQ Page Size, in this example 1 9 -8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Create the IQ Writer Server ■ In the example, we use the default userid, password and port number ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 1 9 -9 Creating a Multiplex Database Create the IQ Writer Server ■ Summary of options for multiplex write server ■ Click finish to create write server ■ The write server will be running in multiplex mode Screens for specifying Case Sensitivity, Ignore Trailing Blanks, Install Java Classes and Sort Order do exist, but were not shown. 19-10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Steps to Set up Multiplex 1. Create the IQ Write Server 2. Create Query Servers 3. Synchronize 4. Add Temp Store for Writer 5. Add Main IQ Store dbspaces 6. Add Temp Store for Reader ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-11 Creating a Multiplex Database Step 2 - Create Reader (Query) Servers ■ Write server must be in Multiplex mode ■ Open Sybase Central - Utilities folder ■ Run Create Reader Wizard ■ Enter appropriate information for: • Host Name for the Query Server • Name for Query Server • Share Directory name • Raw Store Device • Port number In order to create a query server you must have created a multiplex server 19-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Create Query Server ■ Open the Utilities folder ■ Select Create Query Server ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-13 Creating a Multiplex Database Create Query Server ■ Specify the Host Name for the Query Server ■ Give a name for the Query Server 19-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Create Query Server ■ Specify the shared top level directory for the Multiplex ■ Specify the IQ Store raw device ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-15 Creating a Multiplex Database Create Query Server ■ Specify the port number (2638 is the default) Be sure to change the port number if building the Write and Query Servers on the same node. 19-16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Create Query Server ■ Summary of options for the Query Server ■ Click Finish to create a IQ Multiplex Query Server This step can be repeated for the number of Query Servers that will be in the IQ Multiplex configuration ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-17 Creating a Multiplex Database Directory Structure ■ The shared directory contains: • A directory for each server • A subdirectory for the database After this wizard completes you must synchronize in order to use the Query Server. Synchronization is next... 19-18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Steps to Set up Multiplex 1. Create the IQ Write Server 2. Create Query Servers 3. Synchronize 4. Add Temp Store for Writer 5. Add Main IQ Store dbspaces 6. Add Temp Store for Query Server ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-19 Creating a Multiplex Database Step 3 - Synchronize ■ Synchronization Process does the following: • Overwrites all Query Server Catalog Stores with Writer Catalog Store • Resets all SL Remote Control • Reboots all Servers ■ Needs to be done: • Before you start the multiplex for the first time • After the schema has changed (Any DDL changes) • When new query servers are added • After a restore 19 - 20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Synchronize ■ Open the Multiplex Utilities folder in Sybase Central ■ Select Synchronize the Multiplex ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-21 Creating a Multiplex Database What we have so far... ■ Using Sybase Central, we have a write server called MPXServer01 and one query server called Query01 19-22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Steps to Set up Multiplex 1. Create the IQ Write Server 2. Create Query Servers 3. Synchronize 4. Add Temp Store for Writer 5. Add Main IQ Store dbspaces 6. Add Temp Store for Query Server ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-23 Creating a Multiplex Database Why Add A Temp Store? ■ After creating a Write Server there is only a 10MB Temp Store • Much too small to perform any database task ■ Must add Temp Store to Writer before: • Creating any DDL • Loading any data 19 - 24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Step 4 - Add Temp Store for Writer ■ In Sybase Central, access the Multiplex folder ■ Highlight the Writer Server (MPXServer01) ■ Right click and access Properties The temporary store can be raw or file, in this example we show file. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-25 Creating a Multiplex Database Add Temp Store for Writer ■ Click Add DB Space 19-26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Add Temp Store for Writer ■ Follow Wizard ■ Enter name of the IQ Temporary db space ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-27 Creating a Multiplex Database Add Temp Store for Writer ■ Choose the type of dbspace, IQ Temporary data The Main store choice will be locked when the Writer is in Mulitplex mode. 19-28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Add Temp Store for Writer ■ Create the Temp Space ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-29 Creating a Multiplex Database Steps to Set up Multiplex 1. Create the IQ Write Server 2. Create Query Servers 3. Synchronize 4. Add Temp Store for Writer 5. Add Main IQ Store dbspaces 6. Add Temp Store for Query Server 19 - 30 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Step 5 - Add Main IQ Store dbspaces ■ First need to start the Server in Simplex mode ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-31 Creating a Multiplex Database Start Server in Simplex Mode 19-32 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Add Main IQ Store dbspaces ■ Access the multiplex folder • Highlight the Writer server (MPXServer01) • Right click and access Properties • Run the Add dbspace Wizard ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-33 Creating a Multiplex Database Add Main IQ Store Dbspaces ■ Click Add DB Space 19-34 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Add Main IQ Store Dbspaces ■ Create a raw dbspace for the IQ Main Store ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-35 Creating a Multiplex Database Add Main IQ Store Dbspaces ■ Select type of dbspace - Store IQ data In Simplex mode, the Temp Store can not be selected. 19-36 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Add Main IQ Store Dbspaces ■ Leave device size blank as these are all raw devices ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-37 Creating a Multiplex Database Add Main Store Dbspaces ■ We now have ... 19-38 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Stop the Writer Server ■ We are in Simplex Mode, need to stop the write server and Synchronize ■ Access the multiplex folder • Highlight the Writer server (MPXServer01) • Right click and select Stop Be sure to synchronize to ensure the Query Servers know about the new Main Store dbspace. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-39 Creating a Multiplex Database Steps to Set up Multiplex 1. Create the IQ Write Server 2. Create Query Servers 3. Synchronize 4. Add Temp Store for Writer 5. Add Main IQ Store dbspaces 6. Add Temp Store for Query Servers 19 - 40 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database Step 6 - Add Temp Store for the Query Server ■ Similar Steps as for adding temp store for Writer ■ Start the Write Server and all the Query Servers in multiplex mode ■ Using Sybase Central, access the Multiplex folder • Highlight the Reader Server • Right click and access Properties • Run the Add dbspace wizard • Create the Temp Space The Temp space may be raw or file system. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-41 Creating a Multiplex Database Summary ■ Follow the steps using Sybase Central • Create the IQ Write Server • Create Reader Servers • Synchronize • Add Temp Store for Writer • Add Main IQ Store dbspaces • Add Temp Store for Reader • Ready to create DDL and load data! 19 - 42 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Creating a Multiplex Database There is no lab for this module. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 19-43 20 Multiplex Operations Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Module Overview This module provides administration topics relevant to the multiplex environment Objectives After completing this module, you should be able to: ■ Create Database Object, Set Options, Load Data, Run Queries ■ Start and Stop Servers ■ Add/Drop Dbspaces ■ Backup and Restore ©2000 Sybase, Inc. 1 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20- Multiplex Operations Working in the Multiplex Environment ■ Getting Started • Creating Database Objects • Setting Memory • Loading Data • Running Queries ■ Start and Stop Servers ■ Add/Drop Dbspaces ■ Backup and Restore 20-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Creating Database Objects ■ All schema changes must be done on the write server in simplex mode ■ Steps: 1. Backup the database, if needed 2. Start the write server in simplex mode 3. Create objects interactively or with scripts (same as any ASIQ database) 4. Synchronize the multiplex 5. Backup the database (multiplex mode) Creating Objects ©2000 Sybase, Inc. 3 See Module 6, "Creating Tables and Indexes" and Module 13, "Joins" Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20- Multiplex Operations Setting Memory ■ In the top level shared directory modify the params.sql file for all servers to set memory ■ Add the -iqmc and -iqtc switches • -iqmc = main cache size A Specify main cache size in MB • -iqtc = temporary cache size A Specify temp cache size in MB ■ To take effect you must restart all servers params.sql More information on this file is coming in this module. Memory settings See Module 7, "ASIQ Memory Configuration" 20-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Loading Data ■ You can use any of the following methods • Loading from flat files • Inserting specified values • Inserting selected rows from a database ■ You can be in either simplex or multiplex mode • After running in simplex mode you must synchronize Basic loading techniques ■ Module 8, "Loading Data from Files", covers: • fixed-and variable-length flat-file loads. Advanced loading techniques ■ Module 9, "Advanced Data Loading from Files", covers: • Loading from multiple files. • Partial-width loads. • Adding a dbspace during a load. Insert techniques ■ Module 10, "Loading Data Using the INSERT Command," covers inserting from foreign databases. ■ If Loading in Simplex mode, you must synchronize in order to have new versions available on the Query Servers. If Loading in Multiplex mode, synchronization is done automatically by SQL Remote. ■ ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20-5 Multiplex Operations Running Queries ■ Transparent to users that this is a multiplex environment ■ Should set the 'Commit After Select' in the dbisql GUI under Command on menu ■ Or issue a Commit on the Reader ■ You many notice a delay of up to a minute to see changes that were made on the write server • Depends on Write Server's mode (strict vs normal) Using ASIQ 20-6 ■ Module 11, "Using ASIQ," covers SQL statements and functions specific to ASIQ. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Specifying Database Options ■ If you want to specify different database options on one particular server you can edit a script called postsync.sql m Allows you to specify user logins, permissions, etc. which are unique to a particular query server ■ This file runs automatically after synchronization ■ Any option set on the Write Server will be also set on all Query Servers • After Synchronization, the Writer's catalog is copied to all Query Servers ■ Add node specific options in the postsync.sql script to have local options for each server • Cannot set cache sizes using this script (use params.sql) ©2000 Sybase, Inc. 7 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20- Multiplex Operations Postsync.sql Script ■ All servers have this script in their directory ■ This script is executed during synchronization ■ This script contains one entry which should not be removed ■ Add other SQL commands as needed ■ Restrictions: • No DDL or DML • All commands need to be valid SQL commands fro ASIQ 20-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Working in the Multiplex Environment • Getting Started • Creating Database Objects • Setting Memory • Loading Data • Running Queries ■ Start and Stop Servers ■ Add/Drop Dbspaces ■ Backup and Restore ©2000 Sybase, Inc. 9 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20- Multiplex Operations Setting Startup Parameters ■ There is aparams.cfg file that sets options to control server startup ■ This script is located in the database directory for the server ■ It is automatically run when you start a server ■ Example: -n MPXServer01 -c 16m -gd all -gm 10 -gp 4 0 96 -ti 4 4 0 0 -tl 3 0 0 -iqmc 50 0 -iqtc 5 0 0 - x tc pip{ por t=2638} Server switches ■ ■ ■ ■ ■ ■ ■ 20 -10 -n = server name • Required if server is started without a database -c = cache size for Catalog Store • Default = 2 MB • Recommend 16MB to keep entire catalog in cache -gm = limits number of concurrent users • Default = 10 Recommend to set as needed, up to maximum in license -gp = Catalog store page size • Default = 1024 • Recommend 4096 to allow more table columns -ti = default client timeout (minutes) • Interval to disconnect inactive clients • Default = 240, recommend 4400 (~73 hours) -tl = default network timeout (seconds) • Interval a "liveness" packet is sent to a client • Default = 120, recommend 300 or higher Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Starting and Stopping ■ Sybase Central is the easiest way ■ Open the utilities folder and run Start Multiplex ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 2 0 -11 Multiplex Operations Select the Start Mode ■ Choose how to start the servers 20-12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Stopping Multiplex Server ■ To stop the entire multiplex: ■ Choose Stop Multiplex (wrong option is highlighted here) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20-13 Multiplex Operations Stopping Individual Servers ■ Open the database folder in Sybase Central and select the desired server ■ Right click on the server and choose stop from the menu ■ You can also stop individual servers on each node using dbstop (NT) or stop_asiq (UNIX) 20-14 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Managing Servers ■ To view the current state of your server open the Multiplex folder and right-click on the desired server ■ From the popup menu, you can: • Start • Stop • Delete • Properties Delete ©2000 Sybase, Inc. ■ ■ ■ You can only delete query servers You must be running in simplex mode to delete a query server The delete will fail if another user is logged in as DBA Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20-15 Multiplex Operations Restarting Servers ■ If one of the servers in your multiplex becomes unavailable you will need to shut down your multiplex and restart it ■ If the write server fails and can not be restarted you can specify one of the query servers to be the new write server • See Chapter 3 "Managing the Multiplex Environment", in the Adaptive Server IQ Multiplex User's Guide Must Synchronize anytime DDL is performed on the Write Server. 20 -16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Working in the Multiplex Environment • Getting Started • Creating Database Objects • Setting Memory • Loading Data • Running Queries • Start and Stop Servers ■ Add/Drop Dbspaces ■ Backup and Restore ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20-17 Multiplex Operations Adding and Dropping Dbspaces ■ Review: There are two types of dbspaces • permanent (IQ Main Store) • temporary (IQ Temporary Store) ■ Rules • You can not add or remove permanent dbspaces from the database while a multiplex is operating • For a permanent dbspace, the write server must be in simplex mode • For a temporary dbspace, all servers must be started in multiplex mode • To drop temp space on any server contact tech support 20 -18 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations To Add A Permanent (Main) Dbspace Steps: 1. Start the write server in simplex mode 2. Connect to the database and open the Multiplex folder 3. Click on the server name and choose File Properties 4. Click Add Dbspace 5. Follow the wizard 6. Synchronize Add Dbspace ©2000 Sybase, Inc. See Module 19, "Creating a Multiplex Database", page 35-39 for detailed screen shots of the Add Dbspace wizard to create a permanent IQ dbspace. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20-19 Multiplex Operations To Create a Temporary Dbspace Steps 1. Start all the servers in multiplex mode 2. Follow steps 3-5 on the previous page • Note: You do not have to synchronize Add Dbspace 20 - 20 See Module 19, "Creating a Multiplex Database", page 26-30 for detailed screen shots of the Add Dbspace wizard to create a temporary IQ dbspace. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations To Drop a Main or Temporary Dbspace Steps 1. Run Multiplex --> Utilities --> Stop Multiplex 2. Start the write server in simplex mode 3. Start dbisql and run DROP DBSPACE 4. Run Multiplex —-> Utilities —-> Synchronize Multiplex You cannot drop a main dbspace if it is striped and has been loaded. DROP DBSPACE ©2000 Sybase, Inc. See Module 4, "Creating Databases", page 31 for syntax. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20 - 21 Multiplex Operations Working in the Multiplex Environment • Getting Started • Creating Database Objects • Setting Memory • Loading Data • Running Queries • Start and Stop Servers • Add/Drop Dbspaces ■ Backup and Restore 20 - 22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Backup the Multiplex Steps 1. Log onto the Write Server 2. Run the BACKUP command 3. Do a regular file system backup of the partition where the top level share directory is or 1. Stop Write Server 2. Copy all files and dbspaces using OS Level Backup 3. Start Write Server BACKUP command ©2000 Sybase, Inc. See Module 16, "Backup and Restore", for syntax. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20 - 23 Multiplex Operations Restore the Multiplex ■ Perform a restore only when instructed by Technical Support ■ Three possible areas of data failure: • The Main IQ Store, on a shared disk array • The top level shared directory, on an NFS partition or shared disk • One or more .iqtmp files, on local disks ■ Try doing a synchronize first 20 - 24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Multiplex Operations Summary ■ Everything is driven through Sybase Central ■ Working in the Multiplex environment is very similar to working with one node ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 20 - 25 Multiplex Operations There is no lab for this module. 20 - 26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. A Migrating Data from Prior Versions Administering Adaptive Server IQ for the Data Warehouse Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Appendix Overview This appendix provides the necessary background information for migrating data from Adaptive Server IQ version 11.x into Adaptive Server IQ 12.0. Objectives After completing this appendix, you should be able to: ■ Understand the different methods to migrate data from prior versions ■ Choose a method and move data into ASIQ 12.0 from earlier versions ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A -1 Migrating Data from Prior Versions Why Is Data Migration Necessary? ■ The disk format of Adaptive Server IQ 12.0 is different than that of version 11 .x • Need to move data into 12.0 database A-2 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Migration Steps 1. Install ASIQ 12.0 2. Create the 12.0 database • Create dbspaces • Create tables 3. Load the data into the new 12.0 database ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A-3 Migrating Data from Prior Versions Step 1 - Install Version 12.0 ■ See Module 3, "ASIQ Environment and Installation," on how to install ASIQ Version 12.0 ■ May want to upgrade your current Sybase IQ Server to Version 11.5.1EBF 0007 or higher • This provides a parallel unload utility and a command that generates migration scripts A-4 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Step 2 - Create 12.0 Database Two Methods ■ Method 1 - Copy and modify old scripts to build new database ■ Method 2 - Use the database creation script created by the IQ CREATE ASIQ TEMPLATE utility ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A-5 Migrating Data from Prior Versions Method 1 Copy and Modify Old Scripts ■ Copy old scripts from 11 .x IQ Server and modify ■ Need to create a 12.0 database • See Module 4, "Creating Databases" ■ Need to create dbspaces • See Module 4, "Creating Databases" ■ Need to create tables and indexes • See Module 6, "Creating Tables and Indexes" • Review Module 5, "ASIQ Index Types and Data Types," for 12.0 modifications A-6 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Method 2 Database Creation Script ■ To create this script and other migration scripts, the existing ASIQ Server must be 11.5.1 EBF 0007 or higher ■ Must have Open Client 11.1 .x loaded ■ Easiest method ■ The IQ CREATE ASIQ TEMPLATE command creates three scripts for you to use in migration • Database creation script • Data extraction script • Data load script ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A-7 Migrating Data from Prior Versions IQ CREATE ASIQ TEMPLATE ■ Syntax: IQ CREATE ASIQ TEMPLATE PATHNAME = name [APPEND][CREATE] [USEGO] [USESEMICOLON] ■ Example: IQ CREATE ASIQ TEMPLATE PATHNAME = "/home/usr/u/den101/migrate.sql" CREATE USESEMICOLON PATHNAME Required. Specifies the directory and filename for the generated script. Use single or double quotes to enclose name. APPEND| CREATE Specifies whether to append the newly generated script to the existing pathname or create a new file. USEGO| USESEMICOLON Specifies the SQL statement terminator. Either "go" or ";". A-8 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Edit Scripts General Guidelines ■ Divide the output into three files (Search for the word "edit"): • Database creation script • Data extraction script • Data load script ■ Replace all instances of "???" with the appropriate text • In the script there are comments with examples of what text should go there ■ Make any additional edits, as required ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A-9 Migrating Data from Prior Versions Database Creation Script ■ Creates a database with the same name ■ Creates dbspaces ■ Creates tables • Automatically creates the columns in each table alphabetically, regardless of the order in which they were created ■ Edit the database creation script carefully! (continued . . .) If you have permanent private indexspaces in Sybase IQ 11.x, remove those from the script. A -10 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Database Creation Script ■ In ASIQ 12.0 database defaults have changed • You need to specify CASE RESPECT to get a case-sensitive database • You need to specify COLLATION ISO_BINENG to get the ASCII-style collation • The new default behavior is that trailing blanks are significant ■ See Module 4, "Creating Databases," for syntax and examples (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A -11 Migrating Data from Prior Versions Database Creation Script ■ The first part of the script creates the database and connects to the database ■ Example: CREATE DATABASE ‘my_db' CASE IGNORE BLANK PADDING ON IQ PATH ‘my_db' IQ SIZE 1172 BLOCK SIZE 4096 IQ PAGE SIZE 6553 6; ■ There are no .TI files in ASIQ 12.0; therefore, space used for .TI files in 11.5.x should be allocated in the 12.0 main dbspace (continued . . .) A -12 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Database Creation Script ■ The next part of the script creates additional dbspaces ■ Example: CREATE DBSPACE my_db_1 AS '/users/my_db_1' IQ STORE 1172; (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A-13 Migrating Data from Prior Versions Database Creation Script ■ The final part of the script creates tables and indexes ■ Columns in tables are in alphabetic order, regardless of the order they were on your 11.5.x database • May want to change the order and make it match the 11.5.x order ■ Check all indexes to make sure they are correct • Do not use LD indexes; future releases will not support this index ■ Example: CREATE TABLE customer (name varchar(40) NOT NULL ,address varchar(40) NOT NULL ,phone char(10) NOT NULL...) LD index A -14 When a LD index is specified, it is currently replaced with an HG index. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Module Map Step 3 - Loading Data ■ Use migration scripts ■ Load the data from your original source ■ Insert the data from an indexspace ■ Select the data into a file and load Loading data ©2000 Sybase, Inc. Some of these options are not available depending on various factors. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A-15 Migrating Data from Prior Versions Migration Scripts ■ Use the data extraction script • Created using the IQ CREATE ASIQ TEMPLATE command • Run this script on Version 11.5.1 EBF 0007 or higher ■ Use the data load script • Created using the IQ CREATE ASIQ TEMPLATE command • Run this script on Version 12.0 ■ These scripts unload the 11.x data and reload it into a 12.0 database in binary format ■ Scripts need to be edited before running on the appropriate server A -16 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Data Extract Script ■ To be run on Sybase IQ 11.5 Server ■ The unloaded format is in binary ■ You need to specify the tape devices to which you will be writing • You must choose a local tape device ■ You need at least one tape for each indexset (table) in a version 11.x indexspace (database) • You can unload one indexset and specify multiple devices and they will be written to in parallel • You cannot write more than one indexset per tape (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A-17 Migrating Data from Prior Versions Data Extract Script ■ Example: IQ UNLOAD BINARY ASIQ PREVIEW BLOCKFACTOR = 400 TO ‘/dev/rmt/1' SELECT customer_id ,cust_type ,organization r • • • FROM customer go BLOCKFACTOR A -18 The BLOCKFACTOR specified in the IQ UNLOAD must be the same as the BLOCKFACTOR in the LOAD command in the data load script. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Data Load Script ■ To be run on the new 12.0 ASIQ database ■ Must specify the device name for the data ■ Must use QUOTES OFF and ESCAPES OFF ■ Specify the same BLOCKFACTOR that was used in the IQ UNLOAD command (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A-19 Migrating Data from Prior Versions Data Load Script ■ Example: LOAD INTO TABLE customer (customer_id BINARY ,cust_type BINARY ,organization BINARY ...) FROM ‘/dev/rmt/1' FORMAT BINARY STRIP OFF QUOTES OFF ESCAPES OFF PREVIEW ON BLOCK FACTOR 400 UNLOAD FORMAT; A - 20 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Editing Scripts General Notes ■ Careful editing of scripts prevents many load problems ■ Things to look for: • Do not use quotation marks as delimiters for column values • IQ LOAD requires both QUOTES OFF and ESCAPES OFF • Do not use the LIMIT option • Start the database using the start_asiq parameter -gd all ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A - 21 Migrating Data from Prior Versions Running Scripts General Notes ■ Use DBISQL ■ Example: DBISQL -c "uid=dba; pwd=sql; dbf=asiqdemo.db" -q myload.sql A - 22 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Module Map Step 3 - Loading Data • Run migration scripts ■ Load the data from your original source ■ Insert the data from an indexspace ■ Select the data into a file and load ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A - 23 Migrating Data from Prior Versions Load the Data from your Original Source Insert Data Directly from ASE ■ Steps: 1. Connect to both ASE and ASIQ 12 using the same user ID and password 2. On ASIQ, issue a statement using this syntax: INSERT INTO asiq_table LOCATION 'ase_servername.ase_dbname' {select col1, col2, col3, ... from ase_table} 3. Issue a COMMIT to commit the insert You can also use this method to move selected columns from a pre-version 12 ASIQ database into a version 12 database. A - 24 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Load the Data from Your Original Source Load from Original Flat Files ■ See Module 8, "Loading Data from Files" ■ Example: LOAD TABLE customer (customer_id ‘| ' , cust_type ‘| ' , organization ‘| ' , country ‘\x0a' FROM ‘/work/data/customer1. dat' ESCAPES OFF QUOTES OFF WITH CHECKPOINT ON; Loading from flat files requires a large amount of disk space. ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A - 25 Migrating Data from Prior Versions Module Map Step 3 - Loading Data • Run migration scripts • Load the data from your original source ■ Insert the data from an indexspace ■ Select the data into a file and load A - 26 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Insert the Data from an Indexspace Insert Data Directly from 11.5.x Sybase IQ ■ Example: INSERT INTO asiq12_table LOCATION 'asiq11_servername.asiq11_indexspace' {select col1, col2, col3, ... from asiq11_indexset} ■ Issue a COMMIT to commit the insert ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A - 27 Migrating Data from Prior Versions Module Map Step 3 - Loading Data • Run migration scripts • Load the data from your original source • Insert the data from an indexspace ■ Select the data into a file and load A - 28 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Select Data into an ASCII file ■ This method is not recommended due to the following drawbacks: • It is much slower • You cannot use parallel dumping to multiple devices • Requires a large amount of disk space • Must do datatype conversions manually ■ Example: select * from employee ># empfile.dat ■ Then use LOAD TABLE command: LOAD TABLE employee FROM 'c:\\temp\\empfile.dat' ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A - 29 Migrating Data from Prior Versions bcp Data into an ASCII file ■ Must have CIS with IQ Version 11.5.x to bcp out to a file ■ bcp data out to a flat file from IQ 11.5.x, then use LOAD TABLE command on ASIQ version 12 Server ■ Requires a large amount of disk space A - 30 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Migration Notes Data Conversion Issues ■ If you loaded source data in binary format for 11 .x, check to see whether there are date, datetime, or scaled integer columns • You should not load into v12 from the original sources • These datatypes need to be converted into the new format before loading (continued . . .) ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A - 31 Migrating Data from Prior Versions Migration Notes Memory Settings ■ You need to change the defaults for main and temporary cache before loading into the Version 12.0 database ■ Example: SET OPTION "PUBLIC".MAIN_CACHE_MEMORY_MB = #_of_MB SET OPTION "PUBLIC".TEMP_CACHE_MEMORY_MB = #_of_MB ■ Can add these SET OPTION commands to the scripts, but remember to disconnect from the database and reconnect for the settings to take effect A - 32 Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 ©2000 Sybase, Inc. Migrating Data from Prior Versions Summary ■ Choose the best load method for your site. ■ Use migration scripts with caution. • Edit these scripts very carefully! ©2000 Sybase, Inc. Administering Adaptive Server IQ for the Data Warehouse, Version 1.0 A - 33
 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
                                             
                                             
                                             
                                             
                                             
                                             
                                             
                                             
                                             
                                             
                                            