主页:http://www.cnblogs.com/EasonJim/p/6958992.html的分支页。

本章的前提需要先新建数据表及添加默认数据,脚本如下:

--
-- 数据库: `test`
-- -- -------------------------------------------------------- --
-- 表的结构 `student`
-- CREATE TABLE IF NOT EXISTS `student` (
`ID` int(11) NOT NULL AUTO_INCREMENT,
`NAME` varchar(20) NOT NULL,
`AGE` int(11) NOT NULL,
PRIMARY KEY (`ID`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=10 ; --
-- 转存表中的数据 `student`
-- INSERT INTO `student` (`ID`, `NAME`, `AGE`) VALUES
(1, 'Zara', 11),
(2, 'Nuha', 2),
(3, 'Ayan', 15);

及MySQL的JAR包:

        <!-- mysql-connector-java -->
<!-- http://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>6.0.6</version>
</dependency>

一、<sql:setDataSource>

<sql:setDataSource>标签设置了数据源配置变量或将数据源信息保存到一个指定范围的变量中,该变量可用作为其他JSTL数据库操作的输入。

属性:

<sql:setDataSource>标签具有如下所示属性:

属性 描述 是否必需 默认值
driver 要被注册的JDBC驱动程序类名
url 数据库连接的JDBC URL
user 数据库用户名
password 数据库密码
password 数据库密码
dataSource 预先准备的数据库
var 展示数据库的变量名 设置默认
scope 展示数据库的变量范围 页面

实例:

对MySQL数据库设置考虑下述信息:

  • 使用的是JDBC MySQL驱动。

  • 将要连接到本地计算机的TEST数据库中。

  • 将使用user_id和password来访问TEST数据库。

所有上述参数会随着MySQL或任何其他数据库设置而变化。记住上述参数,下面是使用setDataSource标签的一个简单的例子:

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql"%>
<html>
<head>
<title>JSTL sql:setDataSource Tag</title>
</head>
<body> <sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/TEST?serverTimezone=UTC" user="root" password="root"/>
<sql:query dataSource="${snapshot}" sql="select * from student" var="result" />
<c:forEach var="row" items="${result.rows}">
<c:out value="${row.name}"/>:<c:out value="${row.age}"/><br/>
</c:forEach>
</body>
</html>

这将产生如下所示结果:

二、<sql:query>

<sql:query>标签执行SQL SELECT语句并将结果保存到给定范围的变量中。

属性:

<sql:query>标签具有如下所示属性:

属性 描述 是否必需 默认值
sql 要执行的SQL命令(应返回ResultSet) Body
dataSource 要用的数据库连接(覆盖默认值) 默认数据库
maxRows 存储在变量中的结果的最大值 不限
startRow 结果中开始记录的行数 0
var 显示数据库的变量名 设置默认
scope 显示来自数据库的结果的变量范围 页面

实例:

现在编写一个JSP,使用<sql:query>来执行SQL SELECT语句,如下所示:

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql"%>
<html>
<head>
<title>JSTL sql:setDataSource Tag</title>
</head>
<body> <sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/TEST?serverTimezone=UTC" user="root" password="root"/>
<sql:query dataSource="${snapshot}" sql="select * from student" var="result" />
<c:forEach var="row" items="${result.rows}">
<c:out value="${row.name}"/>:<c:out value="${row.age}"/><br/>
</c:forEach>
</body>
</html>

现在尝试访问上述JSP,会出现如下所示结果:

三、<sql:update>

<sql:update>标签执行不返回数据的SQL语句,例如SQL INSERT,UPDATE,或DELETE语句。

属性:

<sql:update>标签具有如下所示属性:

属性 描述 是否必需 默认值
sql 要执行的SQL语句(应不返回ResultSet) Body
dataSource 要使用的数据库连接 (覆盖默认值) 默认数据库
var 存储受影响行数的变量名
scope 存储受影响行数的变量范围 页面

实例:

现在编写JSP,使用<sql:update>标签来执行SQL INSERT语句,从而在表中创建一条记录,如下所示:

<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql"%> <html>
<head>
<title>JSTL sql:update Tag</title>
</head>
<body> <sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/TEST?serverTimezone=UTC" user="root" password="root"/> <sql:update dataSource="${snapshot}" var="count">
INSERT INTO Student (name,age) VALUES ('Jim', '27');
</sql:update> <sql:query dataSource="${snapshot}" var="result">
SELECT * from Student;
</sql:query> <table border="1" width="100%">
<tr>
<th>ID</th>
<th>Name</th>
<th>Age</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.age}"/></td>
</tr>
</c:forEach>
</table> </body>
</html>

现在尝试访问上述JSP,将显示如下所示结果:

四、<sql:param>

<sql:param>标签用于<sql:query><sql:update>标签的嵌套操作,来为一个值的占位符提供值。如果提供了一个空值,那么占位符就会被设置为SQL NULL。

属性:

<sql:param>标签具有如下属性:

属性 描述 是否必需 默认值
value 要设置的参数值 Body

实例:

现在编写JSP,使用<sql:update>标签来执行SQL DELETE语句来从表中删除一条id=3的记录,如下所示:

<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql"%> <html>
<head>
<title>JSTL sql:param Tag</title>
</head>
<body> <sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/TEST?serverTimezone=UTC" user="root" password="root"/> <c:set var="id" value="3"/> <sql:update dataSource="${snapshot}" var="count">
DELETE FROM Student WHERE Id = ?
<sql:param value="${id}" />
</sql:update> <sql:query dataSource="${snapshot}" var="result">
SELECT * from Student;
</sql:query> <table border="1" width="100%">
<tr>
<th>ID</th>
<th>Name</th>
<th>Age</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.age}"/></td>
</tr>
</c:forEach>
</table> </body>
</html>

现在尝试访问上述JSP,会显示如下所示的结果:

五、<sql:dateParam>

<sql:dateParam>标签用作<sql:query><sql:update>的嵌套操作,为值占位符提供日期和时间值。如果提供的是一个空值,那么该占位符的值就会被设置为SQL NULL。

属性:

<sql:dateParam>标签具有如下所示属性:

属性 描述 是否必需 默认值
value 要设置的日期参数的值(java.util.Date) Body
type 日期(只能是日期), 时间(只能是时间),或TIMESTAMP(日期和时间) TIMESTAMP

实例:

1、建表及添加模拟数据:

 create table Students2
(
id int not null,
first varchar (255),
last varchar (255),
dob date
);
INSERT INTO Students2 VALUES (100, 'Zara', 'Ali', '2002/05/16');
INSERT INTO Students2 VALUES (101, 'Mahnaz', 'Fatma', '1978/11/28');

现在编写JSP,将<sql:update>标签与<sql:param><sql:dataParam>标签一起使用来执行SQL UPDATE语句来更新:

<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
<%@ 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"%> <html>
<head>
<title>JSTL sql:dataParam Tag</title>
</head>
<body> <sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/TEST?serverTimezone=UTC" user="root" password="root"/> <%
Date DoB = new Date("2001/12/16");
int studentId = 100;
%> <sql:update dataSource="${snapshot}" var="count">
UPDATE Students2 SET dob = ? WHERE Id = ?
<sql:dateParam value="<%=DoB%>" type="DATE" />
<sql:param value="<%=studentId%>" />
</sql:update> <sql:query dataSource="${snapshot}" var="result">
SELECT * from Students2;
</sql:query> <table border="1" width="100%">
<tr>
<th>Emp ID</th>
<th>First Name</th>
<th>Last Name</th>
<th>DoB</th>
</tr>
<c:forEach var="row" items="${result.rows}">
<tr>
<td><c:out value="${row.id}"/></td>
<td><c:out value="${row.first}"/></td>
<td><c:out value="${row.last}"/></td>
<td><c:out value="${row.dob}"/></td>
</tr>
</c:forEach>
</table> </body>
</html>

现在尝试访问上述 JSP,会出现如下所示结果:

六、<sql:transaction>

注意:表类型应为InnoDB才支持事务。

<sql:transaction>标签用于将<sql:query><sql:update>标签分组到事物中。可以在<sql:transaction>标签中放入和语句一样多的<sql:query><sql:update>标签,使它们成为单独的事物。

如果任何嵌套操作抛出一个异常,它确保由嵌套操作执行的数据库修改要么提交要么回滚。

属性:

<sql:transaction>标签具有如下所示属性:

属性 描述 是否必需 默认值
dataSource 要使用的数据库连接(覆盖默认值) 默认数据库
isolation 事务隔离(READ_COMMITTED,READ_UNCOMMITTED,EPEATABLE_READ,或SERIALIZABLE) 数据库的默认值

实例:

现在编写JSP,使用<sql:update><sql:transaction>标签来执行SQL UPDATE语句。在这里<sql:transaction>标签内的代码要么被完全执行,要么一点也不执行(但经过测试,会只执行不会报错的SQL,所以还必须增加isolation属性,不过会抛出异常,此时需要使用异常标签进行包装处理):

<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*"%>
<%@ 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"%> <html>
<head>
<title>JSTL sql:transaction Tag</title>
</head>
<body> <sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/TEST?serverTimezone=UTC" user="root" password="root"/> <%
Date DoB = new Date("2001/12/16");
int studentId = 100;
%> <sql:transaction dataSource="${snapshot}">
<sql:update var="count">
UPDATE Students2 SET last = 'Ali' WHERE Id = 102
</sql:update>
<sql:update var="count">
UPDATE Students2 SET last = 'Shah' WHERE Id = 103
</sql:update>
<sql:update var="count">
INSERT INTO Students2
VALUES (104,'Nuha', 'Ali', '2010/05/26');
</sql:update>
</sql:transaction> <sql:query dataSource="${snapshot}" var="result">
SELECT * from Students2;
</sql:query> <table border="1" width="100%">
<tr>
<th>Emp ID</th>
<th>First Name</th>
<th>Last Name</th>
<th>DoB</th>
</tr>
<c:forEach var="row" items="${result.rows}">
<tr>
<td><c:out value="${row.id}"/></td>
<td><c:out value="${row.first}"/></td>
<td><c:out value="${row.last}"/></td>
<td><c:out value="${row.dob}"/></td>
</tr>
</c:forEach>
</table> </body>
</html>

现在尝试访问上述 JSP,会出现如下所示结果:

JSTL-SQL标签库的更多相关文章

  1. 转: JSTL SQL标签库 使用

    SQL标签库 JSTL提供了与数据库相关操作的标签,可以直接从页面上实现数据库操作的功能,在开发小型网站是可以很方便的实现数据的读取和操作.本章将详细介绍这些标签的功能和使用方法. SQL标签库从功能 ...

  2. JSP标准标签库(JSTL)--SQL标签库 sql

    了解即可.SQL标签库 No. 功能分类 标签名称 描述 1 数据源标签 <sql:setDataSource> 设置要使用的数据源名称 2 数据库操作标签 <sql:query&g ...

  3. JSTL SQL标签库 使用

    推荐博客:http://blog.sina.com.cn/s/blog_4f925fc30101820u.html 怕博主把原文删了,所以在这里先保存一下. SQL标签库 JSTL提供了与数据库相关操 ...

  4. 小峰servlet/jsp(7)jstl国际化标签库、sql标签库等

    一.jstl国际化标签库: fmt:setLocale 设定用户所在的区域: fmt:formatDate   对日期进行格式化 fmt:requestEncoding 设置所有的请求编码; fmt: ...

  5. (4)JSTL的SQL标签库

    jstl的SQL标签库 SQL tag Library中的标签用来提供在 JSP 页面中可以与数据库进行交互的功能Database access标签库有以下6组标签来进行工作: <sql:set ...

  6. java web(一) 使用sql标签库+tomcat+mysql手动创建一个jsp练习总结

    2016-09-0111:06:53                                     使用sql标签库+tomcat+mysql手动创建一个jsp 1. 1.1安装tomcat ...

  7. Java Servlet(十):JSTL核心标签库

    JSTL全名称:JaveServer Pages Standard Tag Library.JSTL是由JCP(Java Community Process)所定制的标准规范,它主要提供给Java W ...

  8. JSTL标准标签库

    有时使用EL和标准动作达不到目的,于是就引入定制标记. 对于JSP页面创作人员来说,定制标记使用起来比脚本要容易一些.不过对于JAVA程序员来说,简历定制标记处理器反而更困难.幸运的是,已经有了一个标 ...

  9. ⑤早起的鸟儿有虫吃-JSTL核心标签库[收藏]

    介绍 JSTL 全名为Java Server Pages Standard Tag Library(JSP Standard Tag Library),它的中文名称为JSP 标准标签函数库. Web  ...

  10. Javaweb学习笔记——(十三)——————JSTL、JSTL核心标签库、自定义标签、有标签体的标签、带有属性的标签、MVC、Javaweb三层框架

    JSTLApache提供的标签库 jar包:jstl-1.2.jar,如果传MyEclipse,他会在我们导入jar包,无需自己导入,如果没有使用MyEclipse那么需要自行导入.--------- ...

随机推荐

  1. 图解 TCP/IP 第六章 TCP与UDP 笔记6.1 传输层的作用

     图解 TCP/IP  第六章 TCP与UDP   笔记6.1 传输层的作用   传输层必须指出这个具体的程序,为了实现这一功能,使用端口号这样一种识别码.根据端口号,就可以识别在传输层上一层的应用程 ...

  2. 半斤八两中级破解 (四) TCP_UDP协议转向本地验证

    首先要用抓包工具判断是哪种协议,根据封包助手来看,教程中给出的例子是个TCP协议的,此时要记录下包的: 源地址,源端口     目的地址,目的端口   源包大小  目的包大小 然后再重新运行抓包工具和 ...

  3. CentOS6.8 RPM包安装快速zabbix22

    CentOS6.8 RPM包安装快速zabbix22 yum install -y epel-release # yum install -y httpd php php-devel mysql-se ...

  4. 学生管理系统之Java+Mysql

    主页面: 代码如下:package appstu.view; import java.awt.BorderLayout;import java.awt.Dimension;import java.aw ...

  5. python多个装饰器的执行顺序

    def decorator_a(func): print 'Get in decorator_a' def inner_a(*args, **kwargs): print 'Get in inner_ ...

  6. bind - 将一个名字和一个套接字绑定到一起

    SYNOPSIS 概述 #include <sys/types.h> #include <sys/socket.h> int bind(int sockfd, struct s ...

  7. CAD参数绘制直线(com接口)

    用户可以在CAD控件视区任意位置绘制直线. 主要用到函数说明: _DMxDrawX::DrawLine 绘制一个直线.详细说明如下: 参数 说明 DOUBLE dX1 直线的开始点x坐标 DOUBLE ...

  8. element-UI el-table二次封装

    Part.1 为什么要二次封装? 这是 Element 网站的 table 示例: <template> <el-table :data="tableData" ...

  9. win下配置qt creator 能够执行c/c++

    首先需要相关包共四个: qt-win-opensource-4.8.5-mingw.exe qt-creator-windows-opensource-2.8.1.exe MinGW-gcc440_1 ...

  10. 花括号的使用 printf %${width}s , 否则会 去找 $widths

    花括号的使用  printf %${width}s , 否则会 去找  $widths 1 #! /usr/bin/perl   2 use strict;  3 use warnings;  4   ...