<sql:transaction>
标签用于将<sql:query>
和<sql:update>
标签分组到事务中。可以将<sql:query>
和<sql:update>
标签作为语句放在<sql:transaction>
标签内,以创建单个事务。
它确保嵌套操作执行的数据库修改是通过任何嵌套操作抛出异常来提交或回滚。
属性
<sql:transaction>
标签具有以下属性 -
属性 | 描述 | 必需 | 默认 |
---|---|---|---|
dataSource |
要使用的数据库连接(覆盖默认值) | 否 | 默认数据库 |
isolation |
事务隔离(READ_COMMITTED,READ_UNCOMMITTED,REPEATABLE_READ或SERIALIZABLE) | 否 | 数据库的默认值 |
示例
在这个示例中,我们从基础概念和操作开始,在testdb
数据库中创建一个student
表,并在该表中创建几个记录,参考以下SQL语句:
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(64) NOT NULL DEFAULT '',
`sex` char(3) NOT NULL DEFAULT '0',
`birthday` date DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of student
-- ----------------------------
INSERT INTO `student` VALUES ('1', '马得力', '男', null);
INSERT INTO `student` VALUES ('2', '张小玲', '女', '2001-10-25');
INSERT INTO `student` VALUES ('3', '李双达', '男', '2000-10-25');
现在编写一个JSP,它将使用<sql:update>
标签以及<sql:transaction>
标签来执行SQL UPDATE
语句。 这里的<sql:transaction>
标签中的代码将被完全执行或一条语句都不会执行,文件:sql_transaction.jsp 如下所示:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="java.util.Date,java.text.*"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>sql:transaction标签示例</title>
</head>
<body>
<div style="margin: auto; width: 90%">
<h2>sql:transaction标签示例</h2>
<sql:setDataSource var="connection" driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost/testdb?useSSL=false&characterEncoding=utf8"
user="root" password="123456" />
<%
Date DoB = new Date("2001/11/14");
%>
<sql:transaction dataSource="${connection}">
<sql:update var="count">
UPDATE student SET name = '赵子龙' WHERE id = 2
</sql:update>
<sql:update var="count">
UPDATE student SET sex = '未知' WHERE id = 1
</sql:update>
<sql:update var="count">
INSERT INTO student
VALUES (4,'关羽','男' , '1998/09/09');
</sql:update>
</sql:transaction>
<!-- 执行查询语句 -->
<sql:query dataSource="${connection}" var="result">
SELECT * from student;
</sql:query>
<table border="1" width="100%">
<tr>
<th>编号</th>
<th>名字</th>
<th>性别</th>
<th>出生日期</th>
</tr>
<c:forEach var="row" items="${result.rows}">
<tr>
<td><c:out value="${row.id}" /></td>
<td><c:out value="${row.name}" /></td>
<td><c:out value="${row.sex}" /></td>
<td><c:out value="${row.birthday}" /></td>
</tr>
</c:forEach>
</table>
</div>
</body>
</html>
注意:需要将MySQL的连接驱动程序:mysql-connector-java-5.1.40-bin.jar放入到{Webpp}/WEB-INFO/lib目录下。
运行上述项目代码,得到以下结果如下 -