首页 > 代码库 > (4)JSTL的SQL标签库

(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="http://www.mamicode.com/${param.username}">     <sql:dateParam  value ="http://www.mamicode.com/${date}" type="timestamp" />
</sql:query>

 

(4)JSTL的SQL标签库