Todo lo relacionado a tecnologías digitales (Hardware) y Software
viernes, 15 de abril de 2011
martes, 5 de abril de 2011
Trigger Transact Sql
Triggers en Transact SQL
Un trigger( o desencadenador) es una clase especial de procedimiento almacenado que se ejecuta automáticamente cuando se produce un evento en el servidor de bases de datos.
SQL Server proporciona los siguientes tipos de triggers:
- Trigger DML, se ejecutan cuando un usuario intenta modificar datos mediante un evento de lenguaje de manipulación de datos (DML). Los eventos DML son instrucciones INSERT, UPDATE o DELETE de una tabla o vista.
- Trigger DDL, se ejecutan en respuesta a una variedad de eventos de lenguaje de definición de datos (DDL). Estos eventos corresponden principalmente a instrucciones CREATE, ALTER y DROP de Transact-SQL, y a determinados procedimientos almacenados del sistema que ejecutan operaciones de tipo DDL.
Trigger DML.
Los trigger DML se ejecutan cuando un usuario intenta modificar datos mediante un evento de lenguaje de manipulación de datos (DML). Los eventos DML son instrucciones INSERT, UPDATE o DELETE de una tabla o vista.
La sintaxis general de un trigger es la siguiente.
CREATE TRIGGER <Trigger_Name, sysname, Trigger_Name>
ON <Table_Name, sysname, Table_Name>AFTER <Data_Modification_Statements, , INSERT,DELETE,UPDATE>ASBEGIN-- SET NOCOUNT ON added to prevent extra result sets from-- interfering with SELECT statements.SET NOCOUNT ON;-- Insert statements for trigger hereENDAntes de ver un ejemplo es necesario conocer las tablas inserted y deleted.
Las instrucciones de triggers DML utilizan dos tablas especiales denominadas inserted y deleted. SQL Server 2005 crea y administra automáticamente ambas tablas. La estructura de las tablas inserted y deletedes la misma que tiene la tabla que ha desencadenado la ejecución del trigger.
La primera tabla (inserted) solo está disponible en las operaciones INSERT y UPDATE y en ella están los valores resultantes despues de la inserción o actualización. Es decir, los datos insertados. Inserted estará vacia en una operación DELETE.
En la segunda (deleted), disponible en las operaciones UPDATE y DELETE, están los valores anteriores a la ejecución de la actualización o borrado. Es decir, los datos que serán borrados. Deleted estará vacia en una operacion INSERT.
¿No existe una tabla UPDATED? No, hacer una actualización es lo mismo que borrar (deleted) e insertar los nuevos (inserted). La sentencia UPDATE es la única en la que inserted y deleted tienen datos simultaneamente.
No puede se modificar directamente los datos de estas tablas.
El siguiente ejemplo, graba un historico de saldos cada vez que se modifica un saldo de la tabla cuentas.
CREATE TRIGGER TR_CUENTASON CUENTASAFTER UPDATEASBEGINSET NOCOUNT ON;INSERT INTO HCO_SALDOS(IDCUENTA, SALDO, FXSALDO)SELECT IDCUENTA, SALDO, getdate()FROM INSERTEDEND
La siguiente instrucción provocará que el trigger se ejecute:
UPDATE CUENTASSET SALDO = SALDO + 10WHERE IDCUENTA = 1Una consideración a tener en cuenta es que el trigger se ejecutará aunque la instruccion DML (UPDATE, INSERT o DELETE ) no haya afectado a ninguna fila. En este caso inserted y deleted devolveran un conjunto de datos vacio.
Podemos especificar a que columnas de la tabla debe afectar el trigger.
ALTER TRIGGER TR_CUENTASON CUENTASAFTER UPDATEASBEGIN-- SET NOCOUNT ON impide que se generen mensajes de texto-- con cada instrucciónSET NOCOUNT ON;IF UPDATE(SALDO) -- Solo si se actualiza SALDOBEGININSERT INTO HCO_SALDOS(IDCUENTA, SALDO, FXSALDO)SELECT IDCUENTA, SALDO, getdate()FROM INSERTEDENDEND
Los trigger están dentro de la transacción original (Insert, Delete o Update) por lo cual si dentro de nuestro trigger hacemos un RollBack Tran, no solo estaremos echando atrás nuestro trigger sino también toda la transacción; en otras palabras si en un trigger ponemos un RollBack Tran, la transacción de Insert, Delete o Update volverá toda hacia atrás.
ALTER TRIGGER TR_CUENTASON CUENTASAFTER UPDATEASBEGIN-- SET NOCOUNT ON impide que se generen mensajes de texto-- con cada instrucciónSET NOCOUNT ON;INSERT INTO HCO_SALDOS(IDCUENTA, SALDO, FXSALDO)SELECT IDCUENTA, SALDO, getdate()FROM INSERTEDROLLBACKENDEn este caso obtendremos el siguiente mensaje de error:
La transacción terminó en el desencadenador. Se anuló el lote.
Podemos activar y desactivar Triggers a tarvés de las siguientes instrucciones.
-- Desactiva el trigger TR_CUENTASDISABLE TRIGGER TR_CUENTAS ON CUENTASGO-- activa el trigger TR_CUENTASENABLE TRIGGER TR_CUENTAS ON CUENTASGO-- Desactiva todos los trigger de la tabla CUENTASALTER TABLE CUENTAS DISABLE TRIGGER ALLGO-- Activa todos los trigger de la tabla CUENTASALTER TABLE CUENTAS ENABLE TRIGGER ALL
Trigger DDL
Los trigger DDL se ejecutan en respuesta a una variedad de eventos de lenguaje de definición de datos (DDL). Estos eventos corresponden principalmente a instrucciones CREATE, ALTER y DROP de Transact-SQL, y a determinados procedimientos almacenados del sistema que ejecutan operaciones de tipo DDL.
La sintaxis general de un trigger es la siguiente.
CREATE TRIGGER <trigger_name, sysname, table_alter_drop_safety>ON DATABASEFOR <data_definition_statements, , DROP_TABLE, ALTER_TABLE>ASBEGIN...END
La siguiente instrucción impide que se ejecuten sentencias DROP TABLE y ALTER TABLE en la base de datos.
lunes, 4 de abril de 2011
El Ipad de Apple
El pasado 2 de marzo de 2011, la compañía Apple dio a conocer el iPad 2 en un keynote en el Yerba Buena Center, ubicado en San Francisco, California. La segunda versión de su tablet, el iPad, cuenta con evidentes mejorías en cuanto a su procesador de núcleo, peso y bandas de conexión. Conserva su clásica apariencia y no ofrece cambios radicales en su concepto, que sigue gozando de la falta de una competencia fuerte en el mercado.
El dispositivo fue presentado por Steve Jobs (de quien no se esperaba que acudiera al evento debido a los problemas de salud por los que atraviesa), que afirmó, con seguridad, que “2011 será el año de iPad 2”. Estadeclaración, es muy parecida a aquella realizada un año atrás, en la que iPad se convirtió en un fenómeno en tecnología y éxito de ventas para la compañía de la manzana.
Leer más en Suite101: Apple presenta el iPad 2: nueva versión del tablet revolucionario http://www.suite101.net/content/apple-presenta-ipad-2-nueva-version-del-tablet-revolucionario-a42781#ixzz1IZjORYO6
Tecnologías Digitales
LA MARAVILLA DIGITAL EL IPAD DE APPLE
Según el diario taiwanés DigiTimes, Apple ha pedido a su proveedor de componentes electrónicos (Foxconn) que le entregue en el plazo de tres meses a varios cientos de miles de unidades de lo que debería ser la segunda generación del Ipad.
La comercialización del nuevo tablet de la marca Apple podría llegar a finales de febrero de 2011, pocos días después de la tradicional Expo MacWorld.
De 400.000 a 600.000 unidades de segunda generación Ipad deberán ser proporcionados por Foxconn a Apple a menos de 100 días, dice Digitimes.
Suscribirse a:
Entradas (Atom)