(4)JSTL的SQL标签库

jstl的SQL标签库

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

<sql:setDataSource>、<sql:query>、<sql:update>、<sql:transaction>、<sql:param>、<sql:dateParam> 

引入SQL标签库的指令代码为:

<%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>

 1.<sql:setDataSource> 标签:用于设置数据源

  定义一个数据源并保存在"dataSource"变量内
        <sql:setDataSource 
            var="dataSource" 
            url="jdbc:mysql://localhost:3306/exe?charachterEncoding=UTF-8" 
            driver="com.mysql.jdbc.Driver" 
            user="root" 
            password="root"/>

  2.<sql:query> 标签:用于查询
  它标签体内可以是一句查询 SQL,保存的结果是 javax.servlet.jsp.jstl.sql.Result 类型的实例    

<!--使用<sql:query> 标签启动查询,将结果保存到变量"queryResults"中-->
    <sql:query var="queryResults" dataSource="${dataSrc}"> 
        select * from table1 
    </sql:query>
    <!--要取得结果集中的数据可以使用 <c:forEach> 循环来进行-->
    <c:forEach var="row" items="${queryResults.rows}"> 
      <tr> 
               <td>${row.userName}</td> 
               <td>${row.passWord}</td> 
      </tr> 
    </c:forEach>
  其中,"row"是javax.servlet.jsp.jstl.sql.Result实例的变量属性之一,用来表示数据库表中的"列"集合
  循环时,通过"${row.XXX}"表达式可以取得每一列的数据,"XXX"是表中的列名

    3.<sql:update>标签:用于更新数据库,它的标签体内可以是一句更新的 SQL 语句

<sql:update sql="INSERT INTO user(username,pwd) VALUES('aa','123456')"/> 
<sql:update var="rs" dataSource="${dataSource}">
  drop table if exists table1     //drop
  insert into table1(username,pwd) values('a','123')  //insert
  create table user(id int,name varchar(50),pwd varchar(50))  //create
</sql:update>

      4.<sql:transaction>标签:用于事务处理

    <sql:transaction> 标签用于数据库的事务处理,在该标签体内可以使用 <sql:update> 标签和 <sql:query> 标签,而 <sql:transaction> 标签的事务管理将作用于它们之上。 
    <sql:transaction> 标签对于事务处理定义了 read_committed 、 read_uncommitted 、 repeatable_read 、 serializable4 个隔离级别。
    

 <sql:transaction> 
        <sql:update sql="INSERT INTO user(username,pwd) VALUES('aa','123456')"/>
        <sql:update sql="DELETE user WHERE username='bb'"/>
    </sql:transaction> 

   5.<sql:param> 、 <sql:dateParam> 标签:用于向 SQL 语句提供参数

    这两个标签用于向 SQL 语句提供参数,就好像程序中预处理 SQL 的“ ? ”一样
    <sql:param> 标签传递除 java.util.Date 类型以外的所有相融参数, 
    <sql:dateParam> 标签则指定必须传递 java.util.Date 类型的参数。
   

<sql:query var="queryResults" dataSource="${dataSrc}"> 
        select * from user where username=?
        <sql:param value="${param.username}">
     <sql:dateParam  value ="${date}" type="timestamp" />
</sql:query>

 

posted @ 2014-09-04 17:04  雨中飞鹭  阅读(300)  评论(0编辑  收藏  举报