You are on page 1of 29

File Organisation

The database is stored as a collection of files. Each file is a sequence of records. A record is a sequence of fields. First approach:
• • •

assume record size is fixed each file has records of one particular type only different files are used for different relations

This case is the easiest to implement.

26
José Alferes - Adaptado de Database System Concepts - 5th Edition

Monday, March 4, 2013

Fixed-Length Records
Simple approach: • Store record i starting from byte n ! (i – 1), where n is the size of each record. Calculate the block based on that. • Record access is simple. But records may cross blocks!

Modification: do not allow records to cross block boundaries

-

Deletion of record i: alternatives: • move records i + 1, . . ., n to i, . . . , n – 1 • move record n to i • do not move records, but mark deleted records and link all free records on a free list
27

José Alferes - Adaptado de Database System Concepts - 5th Edition

Monday, March 4, 2013

Adaptado de Database System Concepts . 2013 .) 28 José Alferes .Free Lists Store the address of the first deleted record in the file header.5th Edition Monday. March 4. More space efficient representation: reuse space for normal attributes of free records to store pointers. (No pointers stored in in-use records. and so on One can think of these stored addresses as pointers since they “point” to the location of a record. Use this first record to store the address of the second deleted record.

Adaptado de Database System Concepts . March 4.Variable-Length Records Variable-length records arise in database systems in several ways: • Storage of multiple record types in a file.g varchars - Store several records. with variable length.5th Edition Monday. E. in blocks (slotted page) A record cannot be bigger than a slotted page This limits the size of records in a database. 2013 . • Record types that allow variable lengths for one or more fields. which is usually the (default) case • There are special types for big records. that are treated differently (remember the clobs and blobs in Oracle?) 29 José Alferes .

30 José Alferes . entry in the header must be updated.Adaptado de Database System Concepts .Variable-Length Records: Slotted Page Structure - Slotted pages are usually the size of a block Header contains: • number of record entries • end of free space in the block • location and size of each record - Records can be moved around within a page to keep them contiguous with no empty space between them. (Other) pointers should not point directly to record — instead they should point to the entry for the record in header.5th Edition Monday. March 4. 2013 .

March 4. based on the value of the search key of each record Hashing – a hash function computed on some attribute of each record.Adaptado de Database System Concepts . In a multitable clustering file organisation records of several different relations can be stored in the same file • Motivation: store related records on the same block to minimise I/O - The choice of a proper organisation of records in a file is important for the efficiency of real databases! 31 José Alferes .5th Edition Monday. 2013 .Organisation of Records in Files Heap – a record can be placed anywhere in the file where there is space Sequential – store records in sequential order. the result specifies in which block of the file the record should be placed Records of each relation may be stored in a separate file.

March 4. 2013 .Sequential File Organisation Suitable for applications that require sequential processing of the entire file The records in the file are ordered by a search-key 32 José Alferes .5th Edition Monday.Adaptado de Database System Concepts .

Adaptado de Database System Concepts . pointer chain must be updated - Need to reorganise the file from time to time to restore sequential order 33 José Alferes . March 4. 2013 .Sequential File Organization (Cont.) Deletion – use pointer chains Insertion – locate the position where the record is to be inserted • if there is free space insert there • if no free space. insert the record in an overflow block • In either case.5th Edition Monday.

March 4.Multitable Clustering File Organisation Store several relations in one file using a multitable clustering file organisation. 2013 . 34 José Alferes .Adaptado de Database System Concepts .5th Edition Monday.

2013 .Adaptado de Database System Concepts . and for queries involving one single customer and her accounts bad for queries involving only customer • but one can add pointer chains to link records of a particular relation results in variable size records 35 José Alferes .) Multitable clustering organisation of customer and depositor: • • • good for queries involving depositor customer.5th Edition Monday. March 4.Multitable Clustering File Organization (cont.

March 4. each relation is stored in a file • One may rely in the file system of the underlying operating system Multitable clustering may have significant gains in efficiency • But this may not be compatible with the file system of the operating system - Several large scale database management systems do not rely directly on the underlying operating system • The relations are all stored in a single (multitable) file • The database management system manages the file by itself • This requires the implementation of an own file system inside the DBMS 36 José Alferes . 2013 .Adaptado de Database System Concepts .5th Edition Monday.File System In sequential file organisation.

2013 . including passwords Statistical and descriptive data • number of tuples in each relation Physical file organisation information • How relation is stored (sequential/hash/…) • Physical location of relation Information about indices (in the sequel) 37 José Alferes .Adaptado de Database System Concepts .Data Dictionary Storage Data dictionary (also called system catalogue) stores metadata. data about data. March 4. such as - Information about relations • names of relations • names and types of attributes of each relation • names and definitions of views - • integrity constraints User and accounting information. that is.5th Edition Monday.

relation_name. length) User_metadata = (user_name. ! position. relation_name. March 4. number_of_attributes. storage_organization. 2013 .5th Edition Monday. group) Index_metadata = (index_name. encrypted_password. in memory ! A possible catalog representation: Relation_metadata = (relation_name. domain_type.Adaptado de Database System Concepts .) Catalog structure • Relational representation on disk • specialised data structures designed for efficient access.Data Dictionary Storage (Cont. index_type. location) Attribute_metadata = (attribute_name. ! index_attributes) View_metadata = (view_name. definition) 38 José Alferes .

File Organisation in Oracle Oracle has its own buffer management. • A database block need not be the same size of an operating system block. each extent being a set of contiguous database blocks. with complex policies Oracle doesn!t rely on the underlying operating system!s file system A database in Oracle consists of tablespaces: • System tablespace: contains catalog meta-data • User data tablespaces The space in a tablespace is divided into segments: • Data segment • Index segment • Temporary segment (for sort operations) • Rollback segment (for processing transactions) - Segments are divided into extents. 2013 .5th Edition Monday. March 4. but is always a multiple 39 José Alferes .Adaptado de Database System Concepts .

2013 .Adaptado de Database System Concepts .g by dates) • Hash partitioning • Composite partitioning Table data in Oracle can also be (multitable) clustered • One may tune the clusters to significantly improve the efficiency of query to frequently used joins. - Hash file organisation (to be studied next week) is also possible for fetching the appropriate cluster A database can be tuned by an appropriate choice for the organisation of data: • Choosing partitions • Appropriate choice of clusters • Hash or sequential - Tuning makes the difference in big (real) databases! 40 José Alferes .5th Edition Monday.File Organisation in Oracle (cont.) A standard table is organised in a heap (no sequence is imposed) Partitioning of tables is possible for optimisation • Range partitioning (e. March 4.

Chapter 12: Indexing and Hashing José Alferes Sistemas de Bases de Dados 2012/13 41 Monday. March 4. 2013 .

5th Edition Monday.Adaptado de Database System Concepts . 2013 .Chapter 12: Indexing and Hashing Basic Concepts Ordered Indices B+-Tree Index Files • B-Tree Index Files Multiple-Key Access and Bitmap indices Index Definition in SQL Indexing in Oracle Hashing • Static Hashing • Dynamic Hashing Comparison of Ordered Indexing and Hashing 42 José Alferes . March 4.

2013 . March 4. Search Key .5th Edition Monday.Adaptado de Database System Concepts . 43 José Alferes .attribute or set of attributes used to look up records in a file.Basic Concepts Indexing mechanisms are used to speed up access to desired data. An index file consists of records (called index entries) of the form search-key pointer Index files are typically much smaller than the original file Two basic kinds of indices: • Ordered indices: search keys are stored in sorted order • Hash indices: search keys are distributed uniformly across “buckets” using a “hash function”.

g. March 4.5th Edition Monday.. and depends on usage. • records with a specified value in the attribute • or records with an attribute value falling in a specified range of values.Adaptado de Database System Concepts . • This strongly influences the choice of index. 2013 . 44 José Alferes . E.Index Evaluation Metrics Access time Insertion time Deletion time Space overhead Access types supported efficiently.

Primary index: in a sequentially ordered file. 2013 .Adaptado de Database System Concepts . 45 José Alferes . index entries are stored sorted on the search key value. Index-sequential file: ordered sequential file with a primary index. E.Ordered Indices In an ordered index. March 4. - Secondary index: an index whose search key specifies an order different from the sequential order of the file. Also called non-clustering index. as an authors catalog in a library.g. the index whose search key specifies the sequential order of the file. • Also called clustering index • The search key of a primary index is usually but not necessarily the primary key.5th Edition Monday.

5th Edition Monday. 2013 .Dense Index Files Dense index — Index record appears for every search-key value in the file. 46 José Alferes . March 4.Adaptado de Database System Concepts .

5th Edition Monday. • Only applicable (in primary index) when records are sequentially ordered on search-key To locate a record with search-key value K we: • Find index record with largest search-key value < K • Search file sequentially starting at the record to which the index record points 47 José Alferes . March 4.Adaptado de Database System Concepts .Sparse Index Files Sparse Index: contains index records for only some search-key values. 2013 .

March 4. 48 José Alferes . Indices at all levels must be updated on insertion or deletion from the file. 2013 . yet another level of index can be created. access becomes expensive.Adaptado de Database System Concepts .Multilevel Index If the primary index does not fit in memory. and so on. • outer index – a sparse index of primary index • inner index – the primary index file - If the outer index is still too large to fit in main memory.5th Edition Monday. Solution: treat primary index kept on disk as a sequential file and construct a sparse index on it.

) 49 José Alferes .Multilevel Index (Cont. March 4.Adaptado de Database System Concepts . 2013 .5th Edition Monday.

- Index Update: Deletion If deleted record was the only record in the file with its particular searchkey value.5th Edition Monday. › 50 José Alferes . Single-level index deletion: • Dense indices – deletion of search-key: similar to file record deletion. the search-key is deleted from the index also. 2013 . • Sparse indices – › if an entry for the search key exists in the index. March 4. If the next search-key value already has an index entry. it is deleted by replacing the entry in the index with the next search-key value in the file (in search-key order). the entry is deleted instead of being replaced.Adaptado de Database System Concepts .

2013 .Index Update: Insertion Single-level index insertion: • Perform a lookup using the search-key value appearing in the record to be inserted. March 4.Adaptado de Database System Concepts .5th Edition Monday. - Multilevel insertion (as well as deletion) algorithms are simple extensions of the single-level algorithms • the outer indices are sparse. the first search-key value appearing in the new block is inserted into the index. whereas the inner one is dense 51 José Alferes . insert it. › If a new block is created. no change needs to be made to the index unless a new block is created. • Sparse indices – if index stores an entry for each block of the file. • Dense indices – if the search-key value does not appear in the index.

5th Edition Monday.Adaptado de Database System Concepts .Secondary Indices Frequently. one wants to find all the records whose values in a certain field (which is not the search-key of the primary index) satisfy some condition. we may want to find all accounts in a particular branch • Example 2: as above. 2013 . March 4. but where we want to find all accounts with a specified balance or range of balances - We can have a secondary index with an index record for each search-key value 52 José Alferes . • Example 1: In the account relation stored sequentially by account number.

Secondary indices have to be dense.Secondary Indices Example Secondary index on balance field of account - Index record points to a bucket that contains pointers to all the actual records with that particular search-key value. since the file is not sorted by the search key.Adaptado de Database System Concepts .5th Edition Monday. 2013 . March 4. 53 José Alferes .

Primary and Secondary Indices Indices offer substantial benefits when searching for records.when a file is modified.5th Edition Monday. Sequential scan using primary index is efficient. every index on the file must be updated. March 4. versus about 100 nanoseconds for memory access 54 José Alferes .Adaptado de Database System Concepts . but a sequential scan using a secondary index is expensive • Each record access may fetch a new block from disk • Block fetch requires about 5 to 10 micro seconds. 2013 . but updating indices imposes overhead on database modification .