Similarities and Differences (SQL Azure vs. SQL Server)
Similarities and Differences (SQL Azure vs. SQL Server)
Applies to
SQL Azure
Summary
SQL Azure Database is a cloud database service from Microsoft. SQL Azure provides web-facing
database functionality as a utility service. Cloud-based database solutions such as SQL Azure can provide
many benefits, including rapid provisioning, cost-effective scalability, high availability, and reduced
management overhead. This paper provides an architectural overview of SQL Azure Database, and
describes how you can use SQL Azure to augment your existing on-premises data infrastructure or as
your complete database solution.
Copyright
This is a preliminary document and may be changed substantially prior to final commercial release of the
software described herein.
The information contained in this document represents the current view of Microsoft Corporation on the
issues discussed as of the date of publication. Because Microsoft must respond to changing market
conditions, it should not be interpreted to be a commitment on
the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information presented after the
date of publication.
This white paper is for informational purposes only. MICROSOFT MAKES NO WARRANTIES,
EXPRESS, IMPLIED, OR STATUTORY, AS TO THE INFORMATION IN THIS DOCUMENT.
Complying with all applicable copyright laws is the responsibility of the user. Without limiting
the rights under copyright, no part of this document may be reproduced, stored in, or introduced into a
retrieval system, or transmitted in any form or by any means (electronic, mechanical, photocopying,
recording, or otherwise), or for any purpose, without the express written permission of Microsoft
Corporation.
Microsoft may have patents, patent applications, trademarks, copyrights, or other intellectual property
rights covering subject matter in this document. Except as expressly provided in any written license
agreement from Microsoft, the furnishing of this document does not give you any license to these patents,
trademarks, copyrights, or other intellectual property.
Microsoft, ADO.NET Data Services, Cloud Services, Live Services, .NET Services, SharePoint Services,
SQL Azure, SQL Azure Database, SQL Server, SQL Server Express, Sync Framework,
Visual Studio, Windows Live, and Windows Server are trademarks of the Microsoft
group of companies.
2
Contents
Similarities and Differences........................................................................................................................4
Logical Administration vs. Physical Administration...............................................................................4
Provisioning............................................................................................................................................4
Transact-SQL Support.............................................................................................................................5
Features and Types..................................................................................................................................5
Key Benefits of the Service.........................................................................................................................5
Self-Managing.........................................................................................................................................5
High Availability.....................................................................................................................................5
Scalability................................................................................................................................................5
Familiar Development Model..................................................................................................................5
Relational Data Model.............................................................................................................................6
Transact-SQL Support (SQL Azure Database)............................................................................................7
3
Similarities and Differences
Similar to an instance of SQL Server on your premises, SQL Azure exposes a tabular data stream (TDS)
interface for Transact-SQL-based database access. This allows your database applications to use SQL
Azure in the same way that they use SQL Server. Because SQL Azure is a service, administration in SQL
Azure is slightly different.
Unlike administration for an on-premise instance of SQL Server, SQL Azure abstracts the logical
administration from the physical administration; you continue to administer databases, logins, users, and
roles, but Microsoft administers the physical hardware such as hard drives, servers, and storage. This
approach helps SQL Azure provide a large-scale multi-tenant database service that offers enterprise-class
availability, scalability, security, and self-healing.
Because Microsoft handles all of the physical administration, there are some differences between SQL
Azure and an on-premise instance of SQL Server in terms of administration, provisioning, Transact-SQL
support, programming model, and features. For more information, see Guidelines and Limitations (SQL
Azure Database).
Database administration in SQL Azure differs most from SQL Server in terms of physical administration.
SQL Azure automatically replicates all data to provide high availably. SQL Azure also manages load
balancing and, in case of a server failure, transparent fail-over.
To provide this level of physical administration, you cannot control the physical resources of SQL Azure.
For example, you cannot specify the physical hard drive or file group where a database or index will
reside. Because the computer file system is not accessible and all data is automatically replicated, SQL
Server backup and restore commands are not applicable to SQL Azure.
Provisioning
When preparing an on-premises SQL Server deployment, it may be the role of the DBA or IT department
to prepare and configure the required hardware and software. When using SQL Azure, these tasks are
performed by the SQL Azure provisioning process.
You can begin provisioning your SQL Azure databases after you create a Windows Azure Platform
account. This account allows you to access all the services, such as Windows Azure, .NET Services, and SQL
Azure, and is used to set up and manage your subscriptions.
Each SQL Azure subscription is bound to one SQL Azure server at the Microsoft data center. Your SQL
Azure server is an abstraction that defines a grouping of databases. To enable load-balancing and high
availability, databases associated with your SQL Azure server may reside on separate physical computers
at the Microsoft data center.
For more information about provisioning, see SQL Azure Provisioning Model.
4
Transact-SQL Support
Many SQL Server Transact-SQL statements have parameters that allow you to specify file groups or
physical file paths. These types of parameters are not supported in SQL Azure because they have
dependencies on the physical configuration. In such cases, the command is considered partially
supported. For more information about Transact-SQL support, see Transact-SQL Support (SQL Azure
Database).
Because SQL Azure performs the physical administration, any statements and options that attempt to
directly manipulate physical resources will be blocked, such as Resource Governor, file group references,
and some physical server DDL statements. It is also not possible to set server options and SQL trace flags
or use the SQL Server Profiler or the Database Tuning Advisor utilities.
Self-Managing
SQL Azure offers the scale and functionality of an enterprise data center without the administrative
overheads that are associated with on-premise instances of SQL Server. This self-managing capability
enables organizations to provision data services for applications throughout the enterprise without
adding to the support burden of the central IT department or distracting technology-savvy employees
from their core tasks in order to maintain a departmental database application.
With SQL Azure, you can provision your data storage in minutes. This reduces the initial costs of data
services by enabling you to provision only what you need. When your needs change, you can easily
extend your cloud-based data storage to meet those needs.
High Availability
SQL Azure is built on proven Windows Server and SQL Server technologies, and is flexible enough to cope
with any variations in usage and load. The service replicates multiple redundant copies of your data to
multiple physical servers to maintain data availability and business continuity. In the case of a hardware
failure, SQL Azure provides automatic failover to optimize availability for your application.
Scalability
A key advantage of SQL Azure is the ease with which you can scale your solution. After partitioning your
data, the service scales as your data grows. A pay-as-you-grow pricing model makes sure that you only
pay for the storage that you use, so that you can also scale down the service when you do not need it.
5
same TDS interface as SQL Server so that you can use the same tools and libraries to build client
applications for data that is stored in SQL Azure. For more about TDS, see Network Protocols and TDS
Endpoints.
Within each SQL Azure server, you can create multiple databases that have tables, views, stored
procedures, indices, and other familiar database objects. This data model makes good use of your existing
relational database design and Transact-SQL programming skills, and simplifies the process of migrating
existing on-premise database applications to SQL Azure. For more about Transact-SQL and its relationship
to SQL Azure, see Transact-SQL Support (SQL Azure Database).
SQL Azure servers and databases are virtual objects that do not correspond to physical servers and
databases. By insulating you from the physical implementation, SQL Azure enables you to spend time on
your database design.
6
Transact-SQL Support (SQL Azure Database)
Transact-SQL is a language that contains commands used to administer instances of SQL Server including
creating and managing all objects in an instance of SQL Server, and inserting, retrieving, modifying, and
deleting all data in tables. Applications can communicate with an instance of SQL Server by sending
Transact-SQL statements to the server.
Microsoft SQL Azure Database supports a subset of Transact-SQL for SQL Server 2008.
The support for Transact-SQL reference in SQL Azure can be described in three main categories:
The following table summarizes the Transact-SQL support provided by SQL Azure Database at PDC 2009:
Constants
Constraints
Cursors Common Language Runtime
Index management and rebuilding indexes (CLR)
Local temporary tables Database file placement
Reserved keywords Database mirroring
Stored procedures Distributed queries
Statistics management Distributed transactions
Transactions Filegroup management
Triggers Global temporary tables
Tables, joins, and table variables Spatial data and indexes
Transact-SQL language elements such as SQL Server configuration
o Create/drop databases
options
o Create/alter/drop tables SQL Server Service Broker
o Create/alter/drop users and logins System tables
o and so on. Trace Flags
User-defined functions
Views, including sys.synonyms view
For more information about the Transact-SQL support in SQL Azure, see Transact-SQL Reference (SQL
Azure Database).
7
SQL Azure Documentation
http://msdn.microsoft.com/en-us/library/cc512417.aspx