Compartir vía


Lección 2: Configuración de permisos en objetos de base de datos

Se aplica a: SQL Server Base de datos de Azure SQL Azure SQL Managed Instance Sistema de plataforma de análisis (PDW) Base de datos SQL de Microsoft Fabric

Nota:

La ruta de aprendizaje Introducción a las consultas con Transact-SQL proporciona contenido más detallado, junto con ejemplos prácticos.

La concesión de acceso de usuario a una base de datos implica tres pasos. Primero, debe crear un inicio de sesión. El inicio de sesión permite al usuario conectarse a Motor de base de datos de SQL Server. Luego, debe configurar el inicio de sesión como un usuario de una base de datos determinada. Y, por último, debe conceder al usuario permiso a objetos de la base de datos. En esta lección se muestran estos tres pasos y cómo crear una vista y un procedimiento almacenado como el objeto.

Nota

En esta sección se utilizan los objetos creados en Lección 1: Creación de objetos de base de datos. Complete la primera lección antes de continuar con la segunda.

Requisitos previos

Para llevar a cabo este tutorial necesita tener SQL Server Management Studio, así como acceso a una instancia de SQL Server.

Si no tiene acceso a ninguna instancia de SQL Server, seleccione su plataforma en uno de los vínculos siguientes. Si elige la autenticación de SQL, use sus credenciales de inicio de sesión de SQL Server.

Le escuchamos: Si encuentra algo obsoleto o incorrecto en este artículo, como un paso o un ejemplo de código, indíquenoslo. Puede hacer clic en el botón Esta página situado en la sección Comentarios en la parte inferior de esta página. Leemos todos los elementos de comentarios sobre SQL, normalmente el día siguiente. Gracias.

Creación de un inicio de sesión

Para tener acceso a Motor de base de datos, los usuarios necesitan un inicio de sesión. El inicio de sesión puede representar la identidad del usuario como una cuenta de Windows o como un miembro de un grupo de Windows, o el inicio de sesión puede ser un inicio de sesión de SQL Server que solo exista en SQL Server. Siempre que sea posible, use la autenticación de Windows.

De forma predeterminada, los administradores del equipo tienen acceso total a SQL Server. Para esta lección, deseamos tener un usuario con menos privilegios; por tanto, creará una nueva cuenta de autenticación de Windows local en el equipo. Para hacerlo, debe ser un administrador del equipo. A continuación, concede al nuevo usuario acceso a SQL Server.

Creación de una cuenta de Windows

  1. Seleccione Inicio y Ejecutar, en el cuadro Abrir, escriba %SystemRoot%\system32\compmgmt.msc /s y, a continuación, haga clic en Aceptar para abrir el programa Administración de equipos.
  2. En Herramientas del sistema, expanda Usuarios y grupos locales, haga clic con el botón derecho en Usuariosy luego seleccione Nuevo usuario.
  3. En el cuadro Nombre de usuario , escriba Mary.
  4. En los cuadros Contraseña y Confirmar contraseña, escriba una contraseña segura y, a continuación, selección Crear para crear un nuevo usuario de Windows local.

Creación de un inicio de sesión de SQL

En una ventana del Editor de consultas de SQL Server Management Studio, escriba y ejecute el siguiente código reemplazando computer_name con el nombre del equipo. FROM WINDOWS indica que Windows autentica al usuario. El argumento opcional DEFAULT_DATABASE conecta Mary con la base de datos TestData, a menos que la cadena de conexión indique otra base de datos. Esta instrucción introduce el punto y coma como una terminación opcional de una instrucción Transact-SQL.

CREATE LOGIN [computer_name\Mary]
    FROM WINDOWS
    WITH DEFAULT_DATABASE = [TestData];
GO

Esto autoriza al nombre de usuario Mary, autenticado por el equipo, a tener acceso a esta instancia de SQL Server. Si existe más de una instancia de SQL Server en el equipo, debe crear el inicio de sesión en cada instancia a la que Mary deba tener acceso.

Nota

Puesto que Mary no es una cuenta de dominio, este nombre de usuario solo puede autenticarse en este equipo.

Concesión de acceso a una base de datos

Ahora, la cuenta Mary tiene acceso a esta instancia de SQL Server, pero no tiene permiso para acceder a las bases de datos. La cuenta ni siquiera tiene acceso a la base de datos TestData predeterminada hasta que autorice la cuenta como usuario de base de datos.

Para conceder acceso a Mary, cambie a la base de datos TestData y, a continuación, use la instrucción CREATE USER para asignar el inicio de sesión a una usuaria llamada Mary.

Creación de un usuario en una base de datos

Escriba y ejecute las siguientes instrucciones (reemplace computer_name con el nombre de su equipo) para conceder acceso a Mary a la base de datos TestData .

USE [TestData];
GO

CREATE USER [Mary] FOR LOGIN [computer_name\Mary];
GO

Ahora, Mary tiene acceso a SQL Server y a la base de datos TestData .

Creación de vistas y procedimientos almacenados

Como administrador, puede ejecutar la instrucción SELECT desde la tabla Products y la vista vw_Names y ejecutar el procedimiento pr_Names; en cambio, Mary no puede hacerlo. Para conceder a Mary los permisos necesarios, use la instrucción GRANT.

Concesión de permiso a procedimientos almacenados

Ejecute la siguiente instrucción para conceder a Mary el permiso EXECUTE para el procedimiento almacenado pr_Names .

GRANT EXECUTE ON pr_Names TO Mary;
GO

En este escenario, Mary solo puede tener acceso a la tabla Products si utiliza el procedimiento almacenado. Si desea que Mary pueda ejecutar una instrucción SELECT con la vista, también debe ejecutar GRANT SELECT ON vw_Names TO Mary. Para quitar el acceso a objetos de base de datos, use la instrucción REVOKE.

Nota

Si la tabla, la vista y el procedimiento almacenado no son propiedad del mismo esquema, la concesión de permisos es más compleja.

Acerca de GRANT

Para ejecutar un procedimiento almacenado, debe tener permiso EXECUTE. Para tener acceso a datos y cambiarlos, debe tener permisos SELECT, INSERT, UPDATE y DELETE. La instrucción GRANT también se usa para otros permisos, como el permiso para crear tablas.

Pasos siguientes

En el siguiente artículo se muestra cómo quitar objetos de base de datos creados en otras lecciones.

Vaya al siguiente artículo para más información: