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

MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 1 / 10

OF F I C I A L M I C R O S O F T L E A R N I N G P R O D U C T

Contents Part 3 / 15

Module 3 Authorizing Users to Access Resources


Module Overview 3-1
Lesson 1: Authorizing User Access to Objects 3-2
Lesson 2: Authorizing Users to Execute Code 3-6
Lesson 3: Configuring Permissions at the Schema Level 3-9

Module Overview

In the previous modules, you have seen how Microsoft® SQL Server® security is organized and how sets
of permissions can be assigned at the server and database level by using fixed server roles, user-defined
server roles, fixed database roles, and application roles. The final step in authorizing users to access SQL
Server resources is the authorization of users and roles to access server and database objects.
In this module, you will see how these object permissions are managed. In addition to access permissions
on database objects, SQL Server provides the ability to determine which users are allowed to execute
code, such as stored procedures and functions. In many cases, these permissions and the permissions on
the database objects are best configured at the schema level rather than at the level of the individual
object. Schema-based permission grants can simplify your security architecture. You will explore the
granting of permissions at the schema level in the final lesson of this module.

Objectives
After completing this module, you will be able to:
 Authorize user access to objects.
 Authorize users to execute code.
 Configure permissions at the schema level.
MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 2 / 10

Lesson 1 Authorizing User Access to Objects


Before moving on to managing permissions on code, you need to consider how permissions are managed
on database objects. SQL Server has a fine-grained security model that means you can grant the minimum
permissions to users that will allow them to do their work. In particular, permissions can be granted at the
column level, not just at the table and view level. You will also see how you can delegate the work of
granting permissions to other users.

What Are Principals?


Principals are entities that can request and be
granted access to SQL Server resources. Like other
components in the SQL Server authorization
model, principals are arranged in a hierarchy.
 At the Windows® level, principals include
users and groups. If the server is part of a
Windows domain, the users and groups can
be domain-based and, regardless of domain
membership, can be local server accounts.
 At the SQL Server level, you can create logins
for users that are either not Windows users or
users who are part of nontrusted Windows
environments. For example, users in other Windows domains where no trust relationship exists with
the domain containing the SQL Server system. Also, at the SQL Server level, fixed and user-defined
server roles are a form of principal that contains other principals.
 At the database level, principals include database users, fixed and user-defined database roles, and
application roles.
Every principal has two numeric IDs associated with it—a principal ID and a security identifier (SID).

What Are Securables?


Securables are the resources to which the SQL
Server Database Engine authorization system
regulates access. Some securables can be
contained within others, creating nested
hierarchies called scopes that can themselves be
secured. The securable scopes are server,
database, and schema. It is important to
understand the different securable scopes in SQL
Server to effectively plan your security model.
SQL Server principals are assigned or denied
access to specific securables so that they can
complete their work.
GRANT, REVOKE, DENY
Permissions are managed by using the GRANT,
DENY, and REVOKE Transact-SQL statements.
Most permissions (but not all) can also be
managed by using SQL Server Management
Studio (SSMS).

GRANT and REVOKE


A user who has not been granted permission
cannot perform the action related to it. For
example, users have no permission to SELECT data
from tables if they have not been granted
permission at some level. Some other database
engines consider this to be an implicit form of
MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 3 / 10

denial. You can use the GRANT statement to assign permissions on a securable to database users.
Similarly, you can use the REVOKE statement to remove the same permissions.

DENY
In ANSI (American National Standards Institute) SQL, if a user does not have permission to perform an
action, they cannot do so. Therefore, ANSI SQL does not provide a DENY statement.
Because SQL Server is closely linked with the Windows operating system and its group membership
system, a Windows user can receive permissions through their group membership. Therefore, there may
be cases where a user has a permission granted through their group membership that you might want to
remove for the individual.
To support this scenario, SQL Server provides the DENY statement, which you can use to explicitly deny a
user a permission that they may receive from membership of a group or role. This is very similar to the
process for denying permissions work in Windows. For a Windows example, consider that you could
decide that all members of the Salespeople group can access a color printer—except Holly (who is a
member of Salespeople), because she causes problems with it. You grant access to the Salespeople group
then deny it to Holly. SQL Server works in the same way. You could grant SELECT permission on a table to
every member of the Salespeople role, and then deny Holly access to that table.
As with Windows, you should use DENY sparingly. If you need to DENY many permissions, it might
indicate a potential problem with your security design.
Note: The REVOKE statement revokes both GRANT and DENY statements.
Securing Tables and Views
The permissions to access data that apply to tables
and views are SELECT, INSERT, UPDATE, DELETE,
and REFERENCES.
In the following example, SELECT permission on
the Marketing.Salesperson object (which is likely
to be a table or a view) is being granted to the
HRApp user in the MarketDev database:

Applying Permissions
USE MarketDev;
GO

GRANT SELECT ON OBJECT::Marketing.Salesperson TO HRApp;


GO

GRANT SELECT ON Marketing.Salesperson TO HRApp;


GO

Note that two forms of the command are shown. While the full terminology involves OBJECT:: as a prefix,
this is optional. In the second example, the same GRANT statement is shown without the OBJECT:: prefix.
It is not strictly necessary to specify the schema for the table or view, but doing so is highly recommended
to ensure that permissions are granted on the intended object. If the schema name is not specified, the
default schema for the user granting the permission is used. If the object is not found in the user's default
schema, the dbo schema is used instead.

REFERENCES
While the meaning of the SELECT, INSERT, UPDATE, and DELETE permissions will likely be obvious to you,
the meaning and purpose of the REFERENCES permission might not. You need to use the REFERENCES
permission before a foreign key relationship can specify the object as a target, and is only required if no
other permissions exist on the referenced object.
MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 4 / 10

Column-Level Security
In addition to assigning permissions at table or
view level, you can also allocate column-level
permissions. This provides a more granular level of
security for data in your database.

You do not need to execute separate GRANT or


DENY statements for every column where you
wish to assign permissions. When a set of columns
needs to be controlled in the same way, you can
provide a list of columns in a single GRANT or
DENY statement.

Using the GRANT and DENY Statements for Columns


GRANT SELECT ON Marketing.Salesperson (SalespersonID, Name) TO User1;
GO

DENY SELECT ON Marketing.Salesperson (Salary, Bonus) TO User2;


GO

User1 can now access two columns in the Marketing.Salesperson table, but not the whole table.

Table-Level DENY and Column-Level GRANT


If you execute a DENY statement for a user at table level, and then execute a GRANT statement at column
level, the user can still access the columns to which you grant access. However, if you then execute the
table-level DENY statement again, the user is denied all permissions on the table, including on the
columns to which they previously had access.
Row-Level Security
Row-level security (RLS) helps you to control
access to rows in a table. This can be useful in a
variety of scenarios, including when you want a
salesperson to only access customer data for
customers in their region; or when you want to
limit an employee to only access data relevant to
their department. One key advantage of this is
that the logic for the separation is in the actual
database. This reduces the risk of errors in the
application that is allowing inappropriate access,
and simplifies the security implementation for that
table.
Functionally, this is similar to horizontal partitioning of data or including a WHERE clause in a query. You
implement RLS by adding a security predicate defined as an inline table-valued function that returns 1
when the predicate is met.

For more information about RLS, see: Row-Level Security http://aka.ms/Br9x2d


MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 5 / 10

WITH GRANT Option


When you grant permissions to a principal, you
can also give them the right to regrant the same
permissions to other principals by using the WITH
GRANT OPTION clause. This means you can
delegate the responsibility for managing
permissions, but you should use this with
caution—because you then lose control of the
security of that securable.
In the following example, User1 is given
permission to perform updates on the
Marketing.Salesperson table, in addition to the
right to grant this same permission to other users:

Using the WITH GRANT OPTION Clause

GRANT UPDATE ON Marketing.Salesperson TO User1 WITH GRANT OPTION;


GO

CASCADE
The challenge of the WITH GRANT OPTION clause comes when you need to REVOKE or DENY the
permission that you granted to James using the WITH GRANT OPTION. You do not know which other
users James has already granted the permission to.

When revoking or denying a permission, you can use the CASCADE clause to also revoke or deny
permissions from any users who had been granted them by User1.

Using the CASCADE Clause


REVOKE UPDATE ON Marketing.Salesperson FROM User1 CASCADE;
GO

In this example, the REVOKE statement will fail if you omit the CASCADE clause, because the GRANT
statement included the WITH GRANT OPTION clause.
MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 6 / 10

Lesson 2 Authorizing Users to Execute Code


In addition to providing you with control over who accesses data in your database or the objects in your
server, SQL Server helps you to control which users can execute your code. Appropriate security control of
code execution is an important aspect of your security architecture.

In this lesson, you will see how to manage the security of stored procedures and functions. You will also
learn how to manage security for code that lives in .NET-managed code assemblies that are used with SQL
CLR integration. Finally, you will see how ownership chains affect the security relationship between code
and database objects.
Securing Stored Procedures
By default, users cannot execute stored
procedures that other users create unless you
grant them the EXECUTE permission on the stored
procedure. In addition, they might also need
permissions to access the objects that the stored
procedure uses. You will discover more about this
issue later in this lesson.

In the following example, User1 is granted


EXECUTE permission on the
Reports.GetProductColors stored procedure:

Granting EXECUTE Permissions on Stored


Procedures
USE MarketDev;
GO

GRANT EXECUTE ON Reports.GetProductColors TO User1;


GO

Managing Stored Procedures


There are two other permissions related to the management of stored procedures:
 The ALTER permission enables a user to change the definition of a stored procedure.
 The VIEW DEFINITION permission enables a user to view the code definition of the stored procedure.
Note: You can use SSMS or Transact-SQL to grant permissions on user stored procedures,
but you can only grant permissions on system stored procedures by using Transact-SQL code.
Securing User-Defined Functions
You also need to assign users permissions to
execute user-defined functions (UDFs). The
permissions that you need to assign depend on
the type of UDF you are working with.
 Scalar UDFs return a single value. Users
accessing these functions require EXECUTE
permission on the UDF.
 Table-valued UDFs (TVFs) return a table of
results rather than a single value. Accessing a
TVF requires SELECT permission, rather than
EXECUTE permission, similar to the
permissions on a table.
 It is uncommon to directly update a TVF. It is possible, however, to assign INSERT, UPDATE, and
DELETE permissions on one form of TVF known as an inline TVF—in some cases, this particular form
can be updated.

In addition to these permissions, there are scenarios where you also need to assign the REFERENCES
permission to users so that they can correctly execute a UDF. These scenarios include functions that:
MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 7 / 10

 Are used in CHECK constraints.


 Calculate values for DEFAULT constraints.
 Calculate values for computed columns.

Functions often provide low-risk, basic capabilities within systems. Because of this, it is fairly common
practice to grant permissions on basic functions that are contained in a database to the public role of the
database. This means that any user in the database can use those functions without needing further
permission grants.
The following example shows how to grant execute permissions to the public role on the
dbo.FormatPhoneNumber function:

Granting EXECUTE Permissions on UDFs

GRANT EXECUTE ON dbo.FormatPhoneNumber TO public;


GO

Note: Assigning permissions to the public role on stored procedures is not appropriate.
Securing Managed Code
Managed code is .NET Framework code that ships
in assemblies. Assemblies can exist as DLL or EXE
files; however, you can only load assemblies in DLL
files in SQL Server by using SQL Server CLR
integration. After you load an assembly, the
procedures, functions, and other managed code
objects appear as standard objects in SQL Server,
and the standard object permissions apply. For
example, users require EXECUTE permissions to
run a stored procedure, whether it originates in an
assembly or in Transact-SQL code.

Permission Sets
No matter what .NET Framework code is included in an assembly, the actions the code can execute are
determined by the permission set specified when creating the assembly.
 The SAFE permission set strictly limits the actions that the assembly can perform and inhibits it from
accessing external system resources. Code using this permission set can access the local instance of
SQL Server by using a direct access path, called a context connection. The SAFE permission set is the
default.
 The EXTERNAL_ACCESS permission set allows the code to access local and network resources,
environment variables, and the registry. EXTERNAL_ACCESS is even necessary for accessing the same
SQL Server instance if a connection is made through a network interface.
 The UNSAFE permission set relaxes many standard controls over code so you should avoid using it.

The EXTERNAL_ACCESS and UNSAFE permission sets require additional setup. You cannot specify the
requirement for an EXTERNAL_ACCESS permission set when executing the CREATE ASSEMBLY statement.
You should flag the database as TRUSTWORTHY (which is easy, but not recommended) or create an
asymmetric key from the assembly file in the master database, create a login that maps to the key, and
grant the login EXTERNAL ACCESS ASSEMBLY permission on the assembly.
MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 8 / 10

Managing Ownership Chains


All database objects have owners. By default, the
principal_id(owner) property is set to NULL for
new objects and the owner of a schema
automatically owns schema-scoped objects. The
best practice is to have all objects owned by the
schema object owner—therefore, an object with a
NULL principal_id property inherits its ownership
from the schema where it is contained.
When an object such as a stored procedure
references another object, an ownership chain is
established. An unbroken ownership chain exists
when each object in the chain has the same
owner. When an unbroken ownership chain exists, access is permitted to the underlying objects, and
access is given to the top level objects.

Having the same owner for all objects in a schema (which itself also has an owner) simplifies permission
management. However, it is still important to understand that ownership chain problems can occur and
you should know how to resolve them.
Ownership chaining applies to stored procedures, views, and functions. The slide shows an example of
how ownership chaining applies to views or stored procedures.
1. User1 has no permissions on the table owned by User2.

2. User2 creates a view that accesses the table and grants User1 permission to access the view. Access is
granted as User2 is the owner of both the top level object (the view) and the underlying object (the
table).
3. User2 then creates a view that accesses a table owned by User3. Even if User2 has permission to
access the table and grants User1 permission to use the view, User1 will be denied access because of
the broken chain of ownership from the top level object (the view) to the underlying object (the
table).
4. However, if User3 grants User1 permissions directly on the underlying table, he can then access the
view that User2 created to access that table.
MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 9 / 10

Lesson 3 Configuring Permissions at the Schema Level


Schemas are used as containers for objects such as tables, views, and stored procedures. They can be
particularly helpful in providing a level of organization and structure when large numbers of objects exist
in a database. You can also assign security permissions at the schema level, rather than individually on the
objects contained in the schemas. Doing this can greatly simplify the design of system security
requirements.

Lesson Objectives
After completing this lesson, you will be able to:
 Describe user-schema separation.
 Describe the role of object name resolution.
 Grant permissions at schema level.

Overview of User-Schema Separation


You can use schemas to contain objects—such as
tables, functions, stored procedures, views, and so
on—and to provide a security boundary for the
assignment of permissions. You can create a
schema by using the CREATE SCHEMA
statement—the name of the schema forms part of
the multipart naming convention for objects. The
full name of any object is built up as
Server.Database.Schema.Object. You can return a
list of all the schemas in a database by querying
the sys.schemas view.
Schemas can simplify the assignment of
permissions. For example, if you grant the EXECUTE permission on a schema to User1, they can then
execute all stored procedures in the schema. In schemas that contain a large number of objects, this can
expedite the permission granting process.

Note: If you are upgrading applications from SQL Server 2000 or earlier versions, note that
schemas were not used then, and that the naming convention consisted of
Server.Database.Owner.Object. When upgrading databases, SQL Server will automatically create a
schema using the same name as the object owner.
You can assign a default schema to users; this is used when a user refers to an object without specifying a
schema name.

There are a few built-in schemas in SQL Server. The dbo and guest users have associated schemas
attached to their own names. The sys and INFORMATION_SCHEMA schemas are reserved for system
objects that you cannot drop or create objects in.
MOC 20764C | Administering a SQL Database Infrastructure | Module 03 – Authorizing Users to Access Resources | 10 / 10

Object Name Resolution


When you refer to object names in code, SQL Server must
determine which underlying objects you are referring to.

If a database contains more than one table named Product,


each in a different schema, the following code becomes
ambiguous:

Referring to Object Names

SQL Server then has to determine which Product table to use. Most users have a default schema
that is inferred when a schema is not specified. If a user does not have a default schema, SQL Server
assumes the dbo schema.
In SQL Server 2012 and later versions, you can assign a default schema to a Windows Group to
accommodate users created from certificates.

Note: Creating users from certificates is an advanced topic that is beyond the scope of this
course.

When locating an object, SQL Server will first check the user’s default schema. If the object is not found,
SQL Server will then check the dbo schema. Therefore, it is important to include schema names when
referring to an object, as shown in the following example:

Locating Objects

SELECT ProductID, Name FROM Production.Product;

Apart from rare situations, using multipart names leads to more reliable code that does not depend on
default schema settings.

Granting Permissions at Schema Level


Instead of assigning individual permissions on tables,
views, and stored procedures, you can grant permissions at
the schema levels that apply to all the relevant objects in
the schema. This method of assigning permissions can
make them much easier to manage than when you assign
permissions to individual objects.
In the following example, User1 is granted EXECUTE
permissions on the Marketing schema, meaning that they can
execute all stored procedures and scalar functions in the
schema.
They are then granted SELECT permissions on the same schema, so that they can select from all tables,
views, and table-valued functions in the schema:

Granting Permissions
USE MarketDev;
GO

GRANT EXECUTE ON SCHEMA::Marketing TO User1;


GO

GRANT SELECT ON SCHEMA::Marketing TO User1;


GO

You might also like