Pessimistic Concurrency Optimistic Concurrency: Microsoft SQL Server

Download as pdf or txt
Download as pdf or txt
You are on page 1of 6

SQL Server

SQL Server allows multiple clients to use the same database concurrently.
As such, it needs to control concurrent access to shared data, to ensure
data integrity—when multiple clients update the same data, or clients
attempt to read data that is in the process of being changed by another
client. SQL Server provides two modes of concurrency control: pessimistic
concurrency and optimistic concurrency. When pessimistic concurrency
control is being used, SQL Server controls concurrent access by using
locks. Locks can be either shared or exclusive. Exclusive lock grants
the user exclusive access to the data—no other user can access the data
as long as the lock is held. Shared locks are used when some data is being
read—multiple users can read from data locked with a shared lock, but
not acquire an exclusive lock. The latter would have to wait for all shared
locks to be released.

Locks can be applied on different levels of granularity—on entire tables,


pages, or even on a per-row basis on tables. For indexes, it can either
be on the entire index or on index leaves. The level of granularity to
be used is defined on a per-database basis by the database administrator.
While a fine-grained locking system allows more users to use the table
or index simultaneously, it requires more resources, so it does not
automatically yield higher performance. SQL Server also includes two more
lightweight mutual exclusion solutions—latches and spinlocks—which are
less robust than locks but are less resource intensive. SQL Server uses
them for DMVs and other resources that are usually not busy. SQL Server
also monitors all worker threads that acquire locks to ensure that they
do not end up in deadlocks—in case they do, SQL Server takes remedial
measures, which in many cases are to kill one of the threads entangled

Microsoft SQL Server


Analytics Platform System (APS)
Formerly Parallel Data Warehouse (PDW) A massively parallel
processing (MPP) SQL Server appliance optimized for large-scale
data warehousing such as hundreds of terabytes.[19]
Datawarehouse Appliance Edition
Pre-installed and configured as part of an appliance in partnership
with Dell & HP base on the Fast Track architecture. This edition
does not include SQL Server Integration Services, Analysis Services,
or Reporting Services.
Discontinued editions

MSDE
Microsoft SQL Server Data Engine / Desktop Engine / Desktop Edition.
SQL Server 7 and SQL Server 2000. Intended for use as an application
component, it did not include GUI management tools. Later,
Microsoft also made available a web admin tool. Included with some
versions of Microsoft Access, Microsoft development tools, and
other editions of SQL Server.[20]
Personal Edition
SQL Server 2000. Had workload or connection limits like MSDE, but
no database size limit. Includes standard management tools.
Intended for use as a mobile / disconnected proxy, licensed for use
with SQL Server 2000 Standard edition.[20]
Datacenter
SQL Server 2008 R2 Datacenter is a full-featured edition of SQL
Server and is designed for datacenters that need high levels of
application support and scalability. It supports 256 logical
processors and virtually unlimited memory and comes with
StreamInsight Premium edition.[21] The Datacenter edition has been
retired in SQL Server 2012; all of its features are available in
SQL Server 2012 Enterprise Edition.[11]

Architecture
The protocol layer implements the external interface to SQL Server. All operations
that can be invoked on SQL Server are communicated to it via a Microsoft-defined
format, called Tabular Data Stream (TDS). TDS is an application layer protocol, used
to transfer data between a database server and a client. Initially designed and
developed by Sybase Inc. for their Sybase SQL Server relational database engine in
1984, and later by Microsoft in Microsoft SQL Server, TDS packets can be encased in
other physical transport dependent protocols, including TCP/IP, named pipes, and
shared memory. Consequently, access to SQL Server is available over these protocols.
In addition, the SQL Server API is also exposed over web services.[8]

Data storage
Storage space allocated to a database is divided into sequentially numbered pages,
each 8 KB in size. A page is the basic unit of I/O for SQL Server operations. A page
is marked with a 96-byte header which stores metadata about the page including the
page number, page type, free space on the page and the ID of the object that owns it.
Page type defines the data contained in the page: data stored in the database, index,
allocation map which holds information about how pages are allocated to tables and
indexes, change map which holds information about the changes made to other pages
since last backup or logging, or contain large data types such as image or text. While
page is the basic unit of an I/O operation, space is actually managed in terms of an
extent which consists of 8 pages. A database object can either span all 8 pages in an
extent ("uniform extent") or share an extent with up to 7 more objects ("mixed
extent"). A row in a database table cannot span more than one page, so is limited to
8 KB in size. However, if the data exceeds 8 KB and the row contains varchar or
varbinary data, the data in those columns are moved to a new page (or possibly a
sequence of pages, called an allocation unit) and replaced with a pointer to the
data.[22]

For physical storage of a table, its rows are divided into a series of partitions
(numbered 1 to n). The partition size is user defined; by default all rows are in a single
partition. A table is split into multiple partitions in order to spread a database over a
computer cluster. Rows in each partition are stored in either B-tree or heap structure.
If the table has an associated, clustered index to allow fast retrieval of rows, the rows
are stored in-order according to their index values, with a B-tree providing the index.
The data is in the leaf node of the leaves, and other nodes storing the index values for
the leaf data reachable from the respective nodes. If the index is non-clustered, the
rows are not sorted according to the index keys. An indexed view has the same
storage structure as an indexed table. A table without a clustered index is stored in an
unordered heap structure. However, the table may have non-clustered indices to allow
fast retrieval of rows. In some situations the heap structure has performance
advantages over the clustered structure. Both heaps and B-trees can span multiple
allocation units.[23]

Data storage is a database, which is a collection of tables with typed columns. SQL
Server supports different data types, including primitive types such as Integer, Float,
Decimal, Char (including character strings), Varchar (variable length character
strings), binary (for unstructured blobs of data), Text (for textual data) among others.
The rounding of floats to integers uses either Symmetric Arithmetic Rounding or
Symmetric Round Down (fix) depending on arguments: SELECT Round(2.5, 0) gives
3.

Microsoft SQL Server also allows user-defined composite types (UDTs) to be defined
and used. It also makes server statistics available as virtual tables and views (called
Dynamic Management Views or DMVs). In addition to tables, a database can also
contain other objects including views, stored procedures, indexes and constraints,
along with a transaction log. A SQL Server database can contain a maximum of 231
objects, and can span multiple OS-level files with a maximum file size of 260 bytes (1
exabyte).[8] The data in the database are stored in primary data files with an
extension .mdf. Secondary data files, identified with a .ndf extension, are used to
allow the data of a single database to be spread across more than one file, and
optionally across more than one file system. Log files are identified with the .ldf
extension.[8]

Editions
Microsoft makes SQL Server available in multiple editions, with different feature sets
and targeting different users. These editions are:[7][8]

Mainstream editions

Enterprise
SQL Server Enterprise Edition includes both the core database
engine and add-on services, with a range of tools for creating and
managing a SQL Server cluster. It can manage databases as large as
524 petabytes and address 12 terabytes of memory and supports 640
logical processors (CPU cores).[9]
Standard
SQL Server Standard edition includes the core database engine,
along with the stand-alone services. It differs from Enterprise
edition in that it supports fewer active instances (number of nodes
in a cluster) and does not include some high-availability functions
such as hot-add memory (allowing memory to be added while the server
is still running), and parallel indexes.
Web
SQL Server Web Edition is a low-TCO option for Web hosting.
Business Intelligence
Introduced in SQL Server 2012 and focusing on Self Service and
Corporate Business Intelligence. It includes the Standard Edition
capabilities and Business Intelligence tools: PowerPivot, Power
View, the BI Semantic Model, Master Data Services, Data Quality
Services and xVelocity in-memory analytics.[10]
Workgroup
SQL Server Workgroup Edition includes the core database
functionality but does not include the additional services. Note
that this edition has been retired in SQL Server 2012.[11]
Express
SQL Server Express Edition is a scaled down, free edition of SQL
Server, which includes the core database engine. While there are
no limitations on the number of databases or users supported, it
is limited to using one processor, 1 GB memory and 10 GB database
files (4 GB database files prior to SQL Server Express 2008 R2).[12]
It is intended as a replacement for MSDE. Two additional editions
provide a superset of features not in the original Express Edition.
The first is SQL Server Express with Tools, which includes SQL
Server Management Studio Basic. SQL Server Express with Advanced
Services adds full-text search capability and reporting
services.[13]

Specialized editions
Azure
Microsoft Azure SQL Database is the cloud-based version of
Microsoft SQL Server, presented as a platform as a service offering
on Microsoft Azure.
Azure
Azure SQL Data Warehouse is the cloud-based version of Microsoft
SQL Server in a MPP (massively parallel processing) architecture
for analytics workloads, presented as a platform as a service
offering on Microsoft Azure.
Compact (SQL CE)
The compact edition is an embedded database engine. Unlike the other
editions of SQL Server, the SQL CE engine is based on SQL Mobile
(initially designed for use with hand-held devices) and does not
share the same binaries. Due to its small size (1 MB DLL footprint),
it has a markedly reduced feature set compared to the other editions.
For example, it supports a subset of the standard data types, does
not support stored procedures or Views or multiple-statement
batches (among other limitations). It is limited to 4 GB maximum
database size and cannot be run as a Windows service, Compact
Edition must be hosted by the application using it. The 3.5 version
includes support for ADO.NET Synchronization Services. SQL CE does
not support ODBC connectivity, unlike SQL Server proper.
Developer
SQL Server Developer Edition includes the same features as SQL
Server Enterprise Edition, but is limited by the license to be only
used as a development and test system, and not as production server.
Starting early 2016, Microsoft made this edition free of charge to
the public.[14]
Embedded (SSEE)
SQL Server 2005 Embedded Edition is a specially configured named
instance of the SQL Server Express database engine which can be
accessed only by certain Windows Services.
Evaluation
SQL Server Evaluation Edition, also known as the Trial Edition, has
all the features of the Enterprise Edition, but is limited to 180
days, after which the tools will continue to run, but the server
services will stop.[15]
Fast Track
SQL Server Fast Track is specifically for enterprise-scale data
warehousing storage and business intelligence processing, and runs
on reference-architecture hardware that is optimized for Fast
Track.[16]
LocalDB
Introduced in SQL Server Express 2012, LocalDB is a minimal,
on-demand, version of SQL Server that is designed for application
developers.[17] It can also be used as an embedded database.[18]

You might also like