SQL Server 2008 - Sesión #8 - Triggers

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 10

Análisis y Diseño de Bases de Datos con Sql Server 2008

CREAR UN NUEVO TRIGGER EN SQL-SERVER 2008 MANAGEMENT STUDIO


Son procedimientos asociados a una tabla. Se activan cuando se produce una eliminación, modificación o inserción
en la tabla asociada.
Ejemplos de uso de un trigger

Si tenemos una tabla de clientes, y otra de informes, por ej. cada vez que se produzca una baja en clientes,
almacenamos el nombre y apellidos del cliente en informe para posteriormente hacer una estadística con los clientes
borrados.

Tenemos la tabla de nóminas, cada vez que un usuario acceda a ella, el trigger se activa y almacena su nombre en
otra tabla.

PASOS PARA LA CREACIÓN DE UN TRIGGER

1. Expandir la base de datos donde lo van crear

2. Expandir la tabla donde desean crear el trigger.

3. Donde dice Trigger deben de darle click derecho y colocarse en New Trigger.

danilo.rodriguez@fec.uni.edu.ni 1
Análisis y Diseño de Bases de Datos con Sql Server 2008

4. Cuando le dieron click en New Tigger, les va aparecer un código para crear, deben de cambiarlo un poco para
que se vea algo parecido a esto:

5. Cuando terminen de ingresar el código de su nuevo Trigger, únicamente les queda guardarlo con presionando
F5.

Eliminación en Cascada

Vamos a ver un ejemplo de creación de un trigger para cuando borremos un departamento se actualice la tabla
empleados borrando todos aquellos cuyo departamento sea el borrado.

Create Trigger [Borrador]


on Dept
For Delete
As
delete from emp
From emp, deleted
where
emp.dept_no = deleted.dept_no

danilo.rodriguez@fec.uni.edu.ni 2
Análisis y Diseño de Bases de Datos con Sql Server 2008

Con lo que si por ej. borramos el departamento 20 de la tabla dept, este departamento se almacenará en la tabla
Deleted, una vez borrado, se desencadena el trigger, y borraría de la tabla empleados, todos los empleados cuyo nº
de departamento, coincida con el que se ha borrado y almacenado en la tabla deleted. Si borrasemos 4
departamentos con una misma orden, se activaría el trigger con cada departamento borrado.

Ejemplo de Trigger para Update

Como hemos visto en el ejemplo anterior, para borrar existe la tabla de sistema deleted donde almacena los registros
borrados, al igual que para insertar almacena los registros insertados en la tabla inserted, pero para modificar no
existe ninguna tabla update, lo que hace en realidad es insertar en la tabla deleted el registro antes de ser modificado
y en la tabla inserted el registro ya modificado, porque entiende que se ha borrado un registro y se ha insertado otro.
Con lo cuál para crear un trigger que se active con un update, trabajaremos con las tablas deleted e inserted.
Ejemplo Update:

Create Trigger [Modificar]


On Dept
For Update
As
Update emp
set
dept_no = inserted.dept_no
from emp,deleted,inserted
where
emp.dept_no = deleted.dept_no

Con lo que este ejemplo lo que haría es que cuando modificamos un registro en la tabla dept, se activa el trigger, va
a la tabla insert y busca los registros cuyo nº de depto. Coincida con

Ejemplo de Trigger para Insert

En este ejemplo inserto un nuevo empleado y lo que hago es mostrar el empleado insertado desde la tabla inserted.

Create Trigger
Insertar_Emp
On Emp
for Insert
As
Select * from Inserted
Super Ejemplo

El siguiente ejemplo almacenará en una tabla que crearemos un registro con datos de cada fila que borremos,
modifiquemos o insertemos.
Este registro contendrá
Nº de empleado.
Usuario que realizó la consulta de acción.
Fecha de la consulta de acción.
Tipo de operación realizada.

danilo.rodriguez@fec.uni.edu.ni 3
Análisis y Diseño de Bases de Datos con Sql Server 2008

1. Creamos la tabla

2. Creamos el trigger de borrado en la tabla de empleados

Create Trigger Borrador on emp


For Delete
As
Insert into Control (Emp_no, Usuario, Fecha, Operacion)
Select Emp_no,User_Name(), GetDate(),‟Borrado‟
From Deleted

TRIGGERS O DESENCADENADORES

1) Crear un Trigger que borre en cascada sobre la tabla relacionada cuando borremos una sala. Mostrar el
registro borrado al ejecutar el Trigger.

Create Trigger BorrarSala


on Sala
for delete
as
delete from plantilla from sala, deleted
where sala.sala_cod = deleted.sala_cod
select * from deleted

2) Crear un Trigger que se active cuando Actualicemos alguna sala del hospital, modificando sus tablas
relacionadas. Mostrar el registro Actualizado.

Create Trigger ModificarSala


on Sala
for update
as
update plantilla
set sala_cod = inserted.sala_cod
from plantilla
where sala.sala_cod = deleted.sala_cod
select * from inserted

3) Crear un Trigger que se active al eliminar un registro en la tabla hospital y modifique las tablas
correspondientes.

Create trigger BorrarHospital on hospital


for delete
as
delete from plantilla from plantilla,deleted where plantilla.hospital_cod = deleted.hospital_cod
delete from sala from sala,deleted where sala.hospital_cod = deleted.hospital_cod
delete from doctor from doctor,deleted where doctor.hospital_cod = deleted.hospital_cod

danilo.rodriguez@fec.uni.edu.ni 4
Análisis y Diseño de Bases de Datos con Sql Server 2008

4) Crear un Trigger para controlar la inserción de empleados, cuando insertemos un empleado se copiarán
datos sobre la inserción en una tabla llamada CreateTrigger. Los datos que se copiarán son el Número de
empleado, El usuario que está realizando la operación, la fecha y el tipo de operación.

Create Trigger [DAR ALTA]


on Emp
for insert
as
Insert into ControlTrigger (N_emp, Usuario, Fecha, Operación)
Select inserted.emp_no, user_name(), GetDate(), „INSERCION‟
From Inserted

5) Crear un Trigger que actue cuando se modifique la tabla hospital y sobre todas las tablas con las que esté
relacionadas.

Create trigger Hospital on hospital


for update
as
update plantilla
set hospital_cod = inserted.hospital_cod
from plantilla, inserted, deleted
where plantilla.hospital_cod = deleted.hospital_cod
update sala
set hospital_cod = inserted.hospital_cod
from plantilla, inserted, deleted
where sala.hospital_cod = deleted.hospital_cod
update doctor
set hospital_cod = inserted.hospital_cod
from doctor, inserted, deleted
where doctor.hospital_cod = deleted.hospital_cod

6) Crear un Trigger en la tabla plantilla. Cuando actualicemos la tabla plantilla, debemos comprobar que el
hospital que actualizamos existe, si intentamos actualizar el código de hospital, no podremos hacerlo si no
existe relación con algún código de hospital. Realizar el mismo Trigger para las tablas relacionadas con
Hospital.

7) Modificar el Trigger del ejercicio 4, utilizando transacciones y control de errores, si la operación es


correcta, mostrará un mensaje positivo, si la operación no es correcta mostrará el error y un mensaje que
indique que no se ha llevado a cabo la operación.

8) Crear un Trigger que guarde los datos en la tabla ControlTrigger cuando se realice la baja de un empleado.

9) Crear un Trigger que guarde los datos en la tabla ControlTrigger cuando se relice una modificación en un
empleado. Guardar la hora de la actualización en un campo aparte en la tabla ControlTrigger. (Añadir un
campo)

10) Borrar todos los Triggers creados después de haber sido probados y volver a dejar la base de datos como
estaba desde la copia de seguridad.

danilo.rodriguez@fec.uni.edu.ni 5
Análisis y Diseño de Bases de Datos con Sql Server 2008

SEGURIDAD
Para crear un usuario, debemos realizar los siguientes pasos:

- Crear el usuario asignándole una cuenta de inicio de sesión.


- Asignar el usuario a una base de datos y darle permiso de acceso a ella
- Asociar el usuario a una función de usuario la cuál contiene unos determinados permisos para acceder a la
base de datos.

 Cuentas de inicio de sesión

Cuando un usuario se conecta a un servidor, lo hace a través de una cuenta facilitada por el administrador de la base
de datos. Esta cuenta tiene una serie de permisos que el administrador da, estos permisos pueden ser de restricción a
determinadas tablas, o por ejemplo que un usuario pueda solo insertar, o seleccionar en determinadas tablas.

Existen dos formas de entrar a la base de datos, bien mediante el usuario de windows nt ó 2000, ó mediante el
usuario de la base de datos.

Mediante el usuario de windows, facilitamos al equipo desde el que nos conectamos, los recursos del servidor de sql
server, pudiendo incluso bloquear el equipo desde el que se conecta el usuario.

 Acceso a una base de datos

Para que un usuario tenga acceso a una base de datos, después de crearle una cuenta de inicio de sesión, y
asociársela a una base de datos, hemos de darle permisos para que pueda acceder a esa base de datos.
Posteriormente, mediante funciones le indicaremos que es lo que puede hacer en esa base de datos.
Puede tener permisos para una base de datos o para todo el servidor.

 Funciones

Agrupamos usuarios y sobre estos usuarios daremos permisos a ese grupo de usuarios.
Las funciones de usuario, se usan para establecer los permisos que un grupo de usuario tendrá sobre una
determinada base de datos.

Una vez creado el usuario, y asignada la base de datos, podemos asociar este usuario a la función que queramos para
controlar los permisos que tiene sobre la base de datos asignada.

Hay una serie de funciones y usuarios predefinidos en la base de datos.

 Crear un usuario

Para crear un usuario y poder usarlo, hemos de establecer todos los pasos descritos en los puntos anteriores.
Estos pasos, los realizaremos todos en el analizador de consultas:

1. Creamos el inicio de sesión del usuario.

 SP_ADDLOGGIN
Crea una cuenta de inicio para un usuario y lo asigna a una base de datos. Sintaxis:

SP_ADDLOGIN „Usuario‟, „Contraseña‟, „Base de datos‟

EXEC SP_ADDLOGIN 'Pepe', 'Pepe','Hospital'


Creado nuevo inicio de sesión.

danilo.rodriguez@fec.uni.edu.ni 6
Análisis y Diseño de Bases de Datos con Sql Server 2008

 SP_DROPLOGIN
Borra una cuenta de inicio de un usuario, siempre y cuando el usuario no esté conectado y no tenga
permisos sobre ninguna base de datos (si los tiene hemos de revocarlos antes de borrar la cuenta de
inicio y el usuario)Sintaxis:

SP_DROPLOGIN 'Usuario'

EXEC SP_DROPLOGIN 'Pepe'


Inicio de sesión quitado.

Nota: Si el usuario tiene permisos asignados sobre una base de datos, debemos quitar primero esos
permisos antes de borrarlo, ya que sino dará error al intentarlo.

2. Asignamos permisos al usuario sobre la base de datos que queramos

 SP_GRANTDBACCESS

3. Para ello usaremos el procedimiento almacenado de sistema SP_GRANTDBACCESS.


Sintaxis:
SP_GRANTDBACCESS „Usuario‟

Use Hospital
GO
SP_GRANTDBACCESS 'Pepe'
Concedido a la base de datos acceso a 'Pepe'.

Si queremos revocar estos permisos al usuario, usaremos el procedimiento almacenado de sistema


SP_REVOKEDBACCESS. Sintaxis:
SP_REVOKEDBACCESS „Usuario‟
Es decir en este caso sería:
EXEC SP_REVOKEDBACCESS 'Pepe'
El usuario se ha quitado de la base de datos actual.

4. Probamos el usuario creado entrando en el analizador de consulta con su login y password

Una vez en el analizador de consultas, solo tendremos acceso a la base de datos asociada al
usuario y las bases de datos de ejemplo.

5. Asociar el usuario a la función que queramos.

danilo.rodriguez@fec.uni.edu.ni 7
Análisis y Diseño de Bases de Datos con Sql Server 2008

Crear Funciones (grupos de usuarios) y establecer sus permisos

Para ello crearemos la función mediante el procedimiento almacenado de sistema SP_ADDROLE

EXEC SP_ADDROLE 'Becarios'


Agregada la nueva función.

Una vez realizado esto, vemos que en el apartado “Funciones” de la base de datos, está la función creada, si
hacemos doble click sobre ella, vemos que no tiene usuarios asignados.

Para establecer los permisos de la función que hemos creado, usaremos el comando GRANT. Sintaxis:

GRANT Permisos
ON Tabla / Objeto
To Función / Usuarios

Es decir en este caso sería:

GRANT INSERT, UPDATE, DELETE


ON Emp
To Becarios

También podemos establecer permisos directamente sobre los usuarios, poniendo el nombre de estos en lugar de la
función.

GRANT INSERT, UPDATE, DELETE


ON Emp
To Pepe, Pepa

Para denegar permisos sería mediante el comando DENY.


Sintaxis:
DENY Permisos
On Tabla
To Función

DENY SELECT
ON Emp
TO Becarios

Para revocar permisos ya asignados mediante GRANT, usaremos el comando REVOKE

REVOKE Permisos
On Tabla
To Función

REVOKE UPDATE
On Emp
to Becarios

Si después de ejecutar todos estos comandos hacemos doble click sobre la función y vemos los permisos.

danilo.rodriguez@fec.uni.edu.ni 8
Análisis y Diseño de Bases de Datos con Sql Server 2008

Asociar usuarios a una Función.

Para asociar un usuario a una función usaremos el procedimiento almacenado de sistema SP_ADDROLEMEBER.
Sintaxis:
SP_ADDROLEMEMBER „Función‟, „Usuario‟

Es decir, en este caso sería:

EXEC SP_ADDROLEMEMBER 'Becarios', 'Pepe'


'Pepe' agregado a la función 'Becarios'.

Una vez realizados estos pasos, si entramos en el analizador de consultas con el usuario Pepe, si intentamos realizar
una consulta no permitida, nos advertirá mediante un mensaje que no podemos realizar la consulta:

Select * from emp

Servidor: mensaje 229, nivel 14, estado 5, línea 1


Permiso SELECT denegado para el objeto 'EMP', base de datos 'Hospital', propietario 'dbo'.

Para eliminar un usuario de una función, usaremos el procedimiento almacenado de sistema


SP_DROPROLEMEMBER. Sintaxis:
SP_DROPROLEMEMBER „Función‟, „Usuario‟
Es decir en este caso sería:
EXEC SP_DROPROLEMEMBER 'Becarios', 'Pepe'
'Pepe' quitado de la función 'Becarios'.

Una vez tengamos la función sin usuarios asignados, podremos borrarla, para borrarla usaremos el procedimiento
almacenado de sistema SP_DROPROLE. Sintaxis:
SP_DROPROLE „Función‟
En este caso sería:
EXEC SP_DROPROLE „Becarios‟
Función quitada.

SP_ADDSRVROLEMEMBER Añade a una función de sistema el usuario que queramos.


Sintaxis: SP_ADDSRVROLEMEMBER 'Usuario','Funcion'

Damos permiso al usuario para modificar y crear bases de datos.


EXEC SP_ADDSRVROLEMEMBER 'Pepe','DbCreator'
SP_ADDSRVROLEMEMBER 'PEPE','DBCREATOR'

SP_DROPSRVROLEMEMBER Quita a un usuario de la función de sistema usuario que seleccionemos.


Sintaxis: SP_ADDSRVROLEMEMBER 'Usuario','Funcion'
Quitamos de la función al usuario „Pepe‟
EXEC SP_ADDSRVROLEMEMBER 'Pepe','DbCreator'
'PEPE' quitado de la función 'DBCREATOR'.

Otro método que tenemos para poder ofrecer permisos es con la opción
With Grant Option

Con esta opción después de la sentencia de conceder derechos, permito al usuario al que estoy concediendo
permisos pueda conceder permisos a su vez sobre los privilegios que se le han otorgado.

Sintaxis:
Grant Select, Insert, Update, Delete
On Tabla / Vista
To Usuario / Funcion
With Grant Option

danilo.rodriguez@fec.uni.edu.ni 9
Análisis y Diseño de Bases de Datos con Sql Server 2008

Ejemplo:
Un administrador concede permisos a Pepe para poder hacer selecciones sobre la tabla Emp.
Usuario  Administrador
Grant Select
On Emp
To Pepe
With Grant Option

Este usuario podrá a su vez conceder permisos a otro usuario sobre sus privilegios, es decir, sobre la tabla emp y
solamente con Select.

Usuario  Pepe

Grant Select
On Emp
To Luisa

La cadena termina aquí, ya que Pepe no ha concedido permisos a Luisa para que pueda conceder permisos a su vez.
Si el administrador revocase los permisos Select a Pepe, estos permisos se revocan a su vez sobre el usuario Luisa,
ya que no tiene permisos de nadie más para ver la Tabla.
Otra opción es que el usuario Pepe conceda permisos a Luisa pero solamente sobre unos determinados campos.

Grant Select (Emp_no, Apellido, Fecha_alt, Dept_no)


On Emp
To Luisa

Esto se puede utilizar también, pero sería más conveniente utilizar una Vista.

danilo.rodriguez@fec.uni.edu.ni 10

También podría gustarte