Download presentation
Presentation is loading. Please wait.
Published byWilla Carr Modified over 9 years ago
1
DATABASE ADMINISTRATION Pertemuan ke-7
2
Application Performance source : Database Administration the complete guide to practices and procedures chapter 12 by. Craig S. Mullins
3
Designing Applications for Relational Access Design issues to examine when application performance suffers include –Type of SQL. Is the correct type of SQL (planned or unplanned, dynamic or static, embedded or stand-alone) being used for this particular application? –Programming language. Is the programming language capable of achieving the required performance, and is the language environment optimized for database access? –Transaction design and processing. Are the transactions within the program properly designed to assure ACID (atomicity, consistency, isolation, and durability ) properties, and does the program use the transaction processor of choice appropriately and efficiently?
4
Designing Applications for Relational Access Locking strategy. Does the application hold the wrong type of locks, or does it hold the correct type of locks for too long? COMMIT strategy. Does each application program issue SQL COMMIT statements to minimize the impact of locking? Batch processing. Are batch programs designed appropriately to take advantage of the sequential processing features of the DBMS? Online processing. Are online applications designed to return useful information and to minimize the amount of information returned to the user's screen for a single invocation of the program?
5
Relational Optimization The optimizer is the heart of a relational database management system. It is an inference engine responsible for determining the best possible database navigation strategy for any given SQL request. The application developer specifies what data is needed by coding the SQL statements, the DBMS supplies information about where the data is located, and the relational optimizer decides how to efficiently navigate the database. The end user needs no knowledge of where and how the actual data is stored. The optimizer knows this information.
6
Figure 12-1. Relational optimization
7
Every RDBMS has an embedded relational optimizer that renders SQL statements into executable access paths. each vendor's relational optimizer works a little differently, with different steps and using different information. the core of the process is the same from DBMS to DBMS. The optimizer parses the SQL statement and performs various phases of optimization
8
SQL Coding and Tuning for Efficiency steps occur for each SQL statement 1.Identify the business data requirements. 2.Ensure that the required data is available within existing databases. 3.Translate the business requirements into SQL. 4.Test the SQL for accuracy and results. 5.Review the access paths for performance. 6.Tweak the SQL for better access paths. 7.Code optimization hints. 8.Repeat steps 4 through 7 until performance is acceptable. 9.Repeat step 8 whenever performance problems arise or a new DBMS version is installed. 10.Repeat entire process whenever business needs change.
9
SQL Rules of Thumb Rule 1: "It Depends!" –A successful DBA will know on what it depends. Rule 2: Be Careful What You Ask For –Place the most restrictive predicate where the optimizer can read it first. Rule 3: KISS –Keep it simple, Stupid. Rule 4: Retrieve Only What Is Needed
10
Rule 5: Avoid Cartesian Products Rule 6: Judicious Use of OR
11
Rule 7: Judicious Use of LIKE
12
Rule 8: Know What Works Best Rule 9: Issue Frequent COMMITs Rule 10: Beware of Code Generators Rule 11: Consider Stored Procedures
13
Additional SQL Tuning Tips Use indexes to avoid sorting. Create indexes to support troublesome queries. Whenever possible, do not perform arithmetic in SQL predicates. Use the host programming language (Java, COBOL, C, etc.) to perform arithmetic. Use SQL functions to reduce programming effort. Build proper constraints into the database to minimize coding edit checks. Do not forget about the "hidden" impact of triggers. A delete from one table may trigger many more operations. Although you may think the problem is a poorly performing DELETE, the trigger may be the true culprit.
14
Summary Application performance management and SQL tuning is a complex area that requires the active participation of programmers and DBAs. Each DBMS operates differently, and DBAs as well as programmers will need to understand all of the minute details of SQL and application performance management for their DBMS. The relational optimizer combines access path strategies to form an efficient access path for each SQL request. the optimizer is a very complex piece of software, and the DBMS vendors do not share with their customers all the intricacies of how the optimizer works. SQL performance tuning becomes an iterative artistic process, instead of a science
15
Tugas individu 1.Install Oracle 2.Buat tabel mahasiswa (dengan query) 3.Lakukan proses insert data : data anda, dan data 1 orang teman anda KolomTypeNULLDefaultExtra Mhs_npminteger (PK)NOT NULLauto increment (PK) Mhs_namaVarchar(255)NOT NULLMahasiswa- Mhs_thn_masukInteger(4)NULL- Mhs_asal_kotaVarchar(100)NULL- Mhs_catatanTextNULL--
16
Print screen instalasi dan query pembuatan dan insert data Kirim soft copy format laporan ke : tanto.tc04@gmail.com dengan judul :tanto.tc04@gmail.com tugas dba pertemuan 7 (NPM Nama kelas) Contoh : tugas dba pertemuan 7 (111100011 dwi kelas C )
17
Terima kasih
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.