SQLServer DDL触发器示例:防止表删除

需积分: 47 7 下载量 21 浏览量 更新于2024-08-15 收藏 2.5MB PPT 举报
在SQL Server 2005中,创建DDL(数据定义语言)触发器是一个关键的数据库管理技术,它允许在特定数据库事件发生时自动执行预定的操作。DDL触发器主要关注于对数据库结构的改变,如表的创建、删除或修改。本文档主要介绍如何使用T-SQL语法来创建一个名为`safety`的触发器,它针对`DATABASE`级别,对于`AFTER DROP_TABLE`事件,即表被删除后,触发器会阻止删除并打印一条警告消息,随后回滚事务。 触发器的创建遵循以下语法格式: ```sql CREATE TRIGGER trigger_name ON { ALL SERVER | DATABASE } [ WITH ENCRYPTION ] { FOR | AFTER } { event_type | event_group } [ ,...n ] AS { sql_statement [ ; ] [ ...n ] | EXTERNAL NAME assembly_name.class_name.method_name } ``` 在这个例子中,`CREATE TRIGGER`关键字后面跟着触发器名称`safety`,`ON DATABASE`指定触发器的作用范围,`AFTER DROP_TABLE`定义了触发器应在何时执行,即在表删除之后。触发器体中的`PRINT '不能删除该表'`语句用于输出警告信息,而`ROLLBACK TRANSACTION`则表示如果触发条件满足,将撤销表的删除操作。 存储过程在SQL Server中扮演着重要的角色,它们可以接受参数,执行DDL和DML操作,提高性能,并有助于数据库安全和自动化任务。系统存储过程是预定义的,由SQL Server提供,如`sp_help`用于查看系统信息。扩展存储过程是由其他编程语言创建并在SQL Server环境中动态链接的,虽然功能强大但可能存在安全隐患。用户存储过程则是由用户自定义编写的,提供更大的灵活性。 理解并熟练运用DDL触发器和存储过程是数据库管理员和开发人员的重要技能,它们能优化数据库管理流程,确保数据一致性,并简化复杂的数据库操作。在实际应用中,应根据业务需求和性能考虑选择合适的触发器类型和存储过程设计。

我不是要使用只读模式,而是要让它能读能写,我的application.xml文件是这样的 <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mysql?useUnicode=true&characterEncoding=utf-8&useSSL=false"/> <property name="username" value="root"/> <property name="password" value="123456"/> <property name="defaultReadOnly" value="false"/> </bean> <bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="mappingResources"> <list> <value>Teachinfo.hbm.xml</value> </list> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <prop key="hibernate.hbm2ddl.auto">update</prop> </props> </property> </bean> <bean id="hibernateTemplate" class="org.springframework.orm.hibernate5.HibernateTemplate"> <property name="sessionFactory" ref="sessionFactory"/> </bean> <bean id="teacherDao" class="JavaBean.TeacherDaoImpl"> </bean> <bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory"></property> </bean> <context:annotation-config/> <context:component-scan base-package="JavaBean"></context:component-scan> struts.xml文件是这样的

2023-05-25 上传