* Your assessment is very important for improving the workof artificial intelligence, which forms the content of this project
Download chapter07
Microsoft Access wikipedia , lookup
Microsoft SQL Server wikipedia , lookup
Serializability wikipedia , lookup
Entity–attribute–value model wikipedia , lookup
Oracle Database wikipedia , lookup
Ingres (database) wikipedia , lookup
Open Database Connectivity wikipedia , lookup
Extensible Storage Engine wikipedia , lookup
Microsoft Jet Database Engine wikipedia , lookup
Relational model wikipedia , lookup
Concurrency control wikipedia , lookup
Clusterpoint wikipedia , lookup
Concepts of Database Management, Fifth Edition Chapter 7: DBMS Functions Objectives 7  Introduce the functions, or services, provided by a DBMS  Describe how a DBMS handles updating and retrieving data  Examine the catalog features of a DBMS  Illustrate the concurrent update problem and describe how a DBMS handles this problem  Explain the data recovery process in a database environment Concepts of Database Management, 5th Edition 2 Objectives 7  Describe the security services provided by a DBMS  Examine the data integrity features provided by a DBMS  Discuss the extent to which a DBMS achieves data independence  Define and describe data replication  Present the utility services provided by a DBMS Concepts of Database Management, 5th Edition 3 7 Nine Functions of a DBMS  Update and retrieve data Provide catalog services Support concurrent update Recover data Provide security services  Provide data integrity features  Support data independence Support data replication Provide utility services       Concepts of Database Management, 5th Edition 4 7 Update and Retrieve Data  Fundamental capability of a DBMS  Users don’t need to know how data is stored or manipulated  Users add, change, and delete records during updates  Users view and manipulate data during retrieval Concepts of Database Management, 5th Edition 5 7 Figure 7.1: Adding Record Concepts of Database Management, 5th Edition 6 7 Figure 7.2: Updating Record Concepts of Database Management, 5th Edition 7 7 Figure 7.3: Retrieving Data Concepts of Database Management, 5th Edition 8 7 Provide Catalog Services  Stores data about data  Contains descriptions of database components  Often hidden from users  Used by database administrators and programmers  Data dictionary in larger DBMSs Concepts of Database Management, 5th Edition 9 Support Concurrent Update 7  Ensures accuracy when several users update database at same time  Manages complex scenarios for updates Concepts of Database Management, 5th Edition 10 Figure 7.4: Ryan 7 Updates the Database Before update DBMS reads data from database into RAM for Ryan Ryan changes data in RAM DBMS updates database with Ryan’s change Concepts of Database Management, 5th Edition 11 Figure 7.5: Elena 7 Updates the Database After Ryan’s update and before Elena’s DBMS reads database data into RAM for Elena Elena changes data in RAM DBMS updates database with Elena’s change Concepts of Database Management, 5th Edition 12 Figure 7.6a: Lost Update 7 Database before updates DBMS reads database data into RAM for Ryan DBMS reads database data into RAM for Elena Ryan changes data in RAM Concepts of Database Management, 5th Edition 13 7 Figure 7.6b: Lost Update (con’t.) Elena updates data in RAM DBMS updates database with Ryan’s change DBMS updates database with Elena’s change; Ryan’s update is lost! Concepts of Database Management, 5th Edition 14 7 Avoiding Lost Updates  Prohibit  Use shared update batch processing  Implement Concepts of Database Management, 5th Edition locking scheme 15 7 Figure 7.7: Delaying Updates Concepts of Database Management, 5th Edition 16 Figure 7.8a: Locking Scheme 7 Database before updates DBMS reads database data into RAM for Ryan and locks record Elena requests same record and request fails Ryan changes data in RAM; Elena’s request for same record again fails Concepts of Database Management, 5th Edition 17 Figure 7.8b: 7 Locking Scheme (con’t.) DBMS updates database with Ryan’s change; Elena’s request for same record again fails DBMS unlocks record; DBMS reads database data into RAM for Elena and locks record Elena changes data in RAM Concepts of Database Management, 5th Edition 18 7 Figure 7.8b: Locking Scheme (con’t.) DBMS updates database with Elena’s change DBMS unlocks record Concepts of Database Management, 5th Edition 19 7 Locking Schemes  Two-Phase  Locking Locks are held until required updates completed  Deadlock    Occurs when two users hold a lock and require a lock on the resource that the other already has DBMS chooses method to break deadlock One user becomes ‘victim’  Locking   on PC-Based DBMSs Table or row locked, not both Usually more limited than locking facilities on mainframe DBMSs Concepts of Database Management, 5th Edition 20 Locking Schemes (con’t.) 7  Timestamping  DBMS assigns each database update a unique time when the update started  Avoids the need to lock rows  Eliminates processing time needed to apply and release locks  Helps detect and resolve deadlocks Concepts of Database Management, 5th Edition 21 7 Figure 7.9: Deadlock Concepts of Database Management, 5th Edition 22 7 Recovery  Mechanism  Recovery:  Simplest  Other for recovering damaged database return of database to correct state recovery involves using backups recovery methods:  Journaling  Forward recovery  Backward recovery  PC-based Concepts of Database Management, 5th Edition 23 7 Figure 7.12: Forward Recovery Concepts of Database Management, 5th Edition 24 7 Figure 7.13: Backward Recovery Concepts of Database Management, 5th Edition 25 7 Provide Security Services  Prevention of unauthorized access  Encryption - converts data to indecipherable form  Authentication - identification of DBMS user, often with passwords or biometrics  Authorizations - rules to specify data available to certain users  Views  Privacy Concepts of Database Management, 5th Edition 26 7 Provide Data Integrity Features  Rules followed to ensure data is accurately and consistently updated  Key  integrity Foreign key and primary key constraints  Data integrity  Data type  Legal values  Format Concepts of Database Management, 5th Edition 27 Figure 7.21: Integrity Constraints in a DBMS Concepts of Database Management, 5th Edition 7 28 7 Support Data Independence  Programs must be independent of database structure  Considerations  Adding a field  Changing length of field  Creating an index  Adding or changing a relationship Concepts of Database Management, 5th Edition 29 7 Support Data Replication  Manage multiple copies of same data in multiple locations  Maintained  Ease for performance or other reasons of access and portability Concepts of Database Management, 5th Edition 30 Figure 7.22: Replicas From Master Database Concepts of Database Management, 5th Edition 7 31 Figure 7.23: DBMS Synchronizes Databases Concepts of Database Management, 5th Edition 7 32 Provide Utility Services  Assist 7 in general database maintenance  Permit changes to database structure  Permit addition and deletion of indexes  Provide access to operating system services  Support for queries, screen generators, and report generators Concepts of Database Management, 5th Edition 33 Provide Utility Services (con’t.)  Provide support for embedded procedures  Procedural  Nonprocedural  Provide 7 easy-to-use, menu-driven interface Concepts of Database Management, 5th Edition 34 7 Summary  A DBMS provides update and data retrieval functions  DBMS catalog service  Support  concurrent update Prevent shared update, locking systems, timestamp updates  Recovery services allow a database to overcome unexpected failures Concepts of Database Management, 5th Edition 35 7 Summary  Security Services ensure users don’t have access to data they are not authorized to view, update or delete  Data replication services allow you to maintain copies of the data closer to where you use it or to provide for disaster recovery  Your DBMS will provide a set of utility services, such as reporting and access to operating system services Concepts of Database Management, 5th Edition 36
 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
									 
                                             
                                             
                                             
                                             
                                             
                                             
                                             
                                             
                                             
                                             
                                            