TALLER DE PROYECTOS I
JSTL
Índice Introducción a JSTL................................................................................................................... ...2 ¿Qué es JSTL? (JSP Standard Tag Library)...................................................... ..........................2 ¿Cuales son las ventajas de los JSTL?.................................................................................... ....2 ¿Cuales son las desventajas de los JSTL?....................................................................... ...........2 ¿Cuál es el problema con los scriptlets JSP?............................................................................... 3 ¿Como mejoran esta situación la librería JSTL?............................................................. .............3 Lenguaje de expresión JSTL............................................................................................ ............3 Instalación y configuración del JSTL........................................................................ ....................6 Librerías englobada en el JSTL(Tags)................................................................................. .........7
•
La Librería Core......................................................................................................... ......7
•
La Librería XML ......................................................................................... .....................9
•
La Librería I18N & Formatting fmt.......................................................................... ........11
•
Acceso a la Base de Datos (SQL).............................................................. ..................13
Referencias......................................................................................................... .......................15
UNMSM- FISI
PAG. 1
TALLER DE PROYECTOS I
JSTL
Introducción JSTL responde a la demanda de los desarrolladores de un conjunto de acciones JSP personalizadas para manejar las tareas que necesitan casi todas las páginas JSP, incluyendo procesamiento condicional, internacionalización, acceso a bases de datos y procesamiento XML. Esto acelerará el desarrollo de JSPs más o menos eliminando la necesidad de elementos de scripting y los inevitables y difíciles de encontrar errores de sintaxis, y liberando el tiempo anteriormente gastado en desarrollar y aprender trillones de acciones personalizadas específicas del proyecto para estas tareas comunes.
¿Qué es JSTL? (JSP Standard Tag Library) La librería JSTL es un componente dentro de la especificación del Java 2 Enterprise Edition (J2EE) y es controlada por Sun MicroSystems. JSTL no es más que un conjunto de librerías de etiquetas simples y estándares que encapsulan la funcionalidad principal que es usada comúnmente para escribir páginas JSP. Las etiquetas JSTL están organizadas en 4 librerías: • • • •
core: Comprende las funciones script básicas como loops, condicionales, y entrada/salida. xml: Comprende el procesamiento de xml y para XML-Transformation. fmt: Comprende la internacionalización y formato de valores como de moneda y fechas. sql: Comprende el acceso a base de datos.
¿Cuales son las ventajas de los JSTL? • •
Acelera el desarrollo de JSPs eliminando la necesidad de elementos scrpting y los errores de sintaxis. Evita la escritura innecesaria de código ya preparado.
¿Cuales son las desventajas de los JSTL? •
•
Los JSTL pueden agregar mayor sobrecarga en el servidor. Los scriptlets y las librerías de etiquetas son compilados a servlets, los cuales luego son ejecutados por el contenedor. El código Java embebido en los scriptlets es básicamente copiado en el servlet resultante. En cambio, las etiquetas JSTL, causan un poco más de código en el servlet. En la mayoría de casos esta cantidad no es mensurable pero debe ser considerado. Los scriptlets son más potentes que las etiquetas JSTL. Si desea hacer todo en un script JSP pues es muy probable que insertará todo el código en Java en él. A pesar que las etiquetas JSTL proporciona un potente conjunto de librerías reutilizables, no puede hacer todo lo que el código Java puede hacer. La librería JSTL está diseñada para facilitar la codificación en el lado de presentación que es típicamente encontrado en la capa de Vista si hablamos de la arquitectura Modelo-Vista-Controlador.
UNMSM- FISI
PAG. 2
TALLER DE PROYECTOS I
JSTL
¿Cuál es el problema con los scriptlets JSP? La especificación JSP ahora se ha convertido en una tecnología estándar para la creación de sitios Web dinámicos en Java, y el problema es que han aparecido algunas debilidades: • • •
•
La recuperación de objetos fuera del HTTP Request y Session es complicada. Es necesario hacer el Casting de objetos y esto ocasiona que tengamos que importar más Clases en los JSP. El código Java embebido en scriptlets es desordenado. Un programador que no conoce Java no puede modificar el código Java embebido, anulando uno de los mayores beneficios de los JSP: permitir a los diseñadores y personas que escriben la lógica de presentación que actualicen el contenido de la página. El código de Java dentro de scriptlets JSP no pueden ser reutilizados por otros JSP, por lo tanto la lógica común termina siendo re-implementado en múltiples páginas.
¿Como mejoran esta situación la librería JSTL? Esto se da a través de: • • •
•
Las etiquetas JSTL encapsulan la lógica como el formato de fechas y números. Usando los scriptlets JSP, esta misma lógica necesitaría ser repetida en todos los sitios donde es usada, o necesitaría ser movida a Clases de ayuda. Debido a que las etiquetas JSTL son XML, estas etiquetas se integran limpia y uniformemente a las etiquetas HTML. Las 4 librerías de etiquetas JSTL incluyen la mayoría de funcionalidad que será necesaria en una página JSP. Las etiquetas JSTL son muy sencillas de usarlas para personas que no conocen de programación, a lo mucho necesitarán conocimientos de etiquetas del estilo HTML. Las etiquetas JSTL pueden referenciar objetos que se encuentren en los ambientes Request y Session sin conocer el tipo del objeto y sin necesidad de hacer el Casting.
Los JSP EL (Expression Language) facilitan las llamadas a los métodos Get y Set en los objetos Java. Esto no es posible en la versión JSP 1.2, pero ahora está disponible en JSP 2.0. EL es usado extensamente en la librería JSTL.
Lenguaje de expresión JSTL Es un lenguaje para acceder a datos de varias fuentes en tiempo de ejecución. Su sintaxis es considerablemente más amigable que la de Java, que es el único lenguaje soportado directamente por la especificación JSP 1.2. Todas las acciones JSTL reconocen expresiones EL (Lenguaje de Expresiones) en sus valores de atributos, y se podrían desarrollar acciones personalizadas para que hicieran lo mismo. Se espera que EL sea incorporado dentro de la próxima versión de la especificación JSP para mejorar su uso para acceder a datos sobre el lenguaje Java. Si es así, podremos usar expresiones EL en un valor de atributo de una acción, o incluso en una plantilla de texto. EL toma prestada la sintaxis de JavaScript para acceder a estructuras de datos tanto como propiedades de un objeto (con el operador “.”) como con elementos con nombres de un array (con el operador ["nombre"]). Las propiedades de los componentes JavaBeans y las entradas java.util.Map, que usan la clave como nombre de propiedad, pueden ser accedidas de esta forma. Aquí tenemos algunos ejemplos: ${myObj.myProperty}$ ${myObj["myProperty"]}$
UNMSM- FISI
PAG. 3
TALLER DE PROYECTOS I
JSTL
${myObj[varWithTheName]}$
Como se observa en el ejemplo anterior, una expresión EL siempre debe estar encerrada entre los caracteres ${y} $. Las dos primeras expresiones acceden a una propiedad llamada myProperty en un objeto representado por una variable llamada myObj. La tercera expresión accede a una propiedad con un nombre contenido en un variable, esta sintaxis se puede utilizar con cualquier expresión que evalúe el nombre de la propiedad. El operador de acceso a array también se usa para datos representados como una colección de elementos indexados, como un array Java o una java.util.List: ${myList[2]}$ ${myList[aVar + 1]}$ Además de los operadores de propiedad y elemento array y los operadores aritméticos, relacionales, y lógicos, hay un operador especial para comprobar si un objeto está "vacío" o no puede ser usado en una expresión EL. La siguiente tabla lista todos los operadores: Operador . [] () + / o div % o mod == o eq != o ne < o lt > o gt <= o le >= o gt && o and || o or ! o not empty
Descripción Accede a una propiedad Accede a un elemento de un array/lista Agrupa una sub-expresión Suma Resta o negación de un número División Módulo (resto) Comprueba Igualdad Comprueba desigualdad Comprueba menor que Comprueba mayor que Comprueba menor o igual que Comprueba mayor o igual que Comprueba AND lógico Comprueba OR lógico Complemento binario booleano Comprueba un valor vacío (null, string vacío, o una colección vacía)
Lo que no encontraremos en EL son sentencias como asignaciones, if/else, o while. Para este tipo de funcionalidades en JSP se usan los elementos Action. EL no está pensado para utilizarse como un lenguaje de programación de propósito general, sólo un lenguaje de acceso a datos. Por supuesto, los literales y las variables, también son parte del lenguaje. EL proporciona los siguientes literales, similares a los que proporcionan JavaScript, Java, y otros lenguajes similares: Tipo de Literal String Integer Coma Floating
UNMSM- FISI
Descripción Va encerrada con comillas simples o dobles. Una comilla del mismo tipo dentro del string puede ser escapada con una barra invertida: (\' en un string encerrado con comillas simples; \" en un string encerrado con comillas dobles). El carácter de barra invertida debe se escapado como \\ en ambos casos. Un signo opcional (+ o -) seguido por dígitos entre 0 y 9. Lo mismo que un literal entero, excepto que usa un punto como
PAG. 4
TALLER DE PROYECTOS I
Boolean Null
JSTL
separador de la parte fraccional y que se puede especificar un exponente con e o E, seguido por un literal entero. true o false. null.
Cualquier objeto en uno de los ámbitos de JSP (página, solicitud, sesión o aplicación) se puede utilizar como una variable en una expresión EL. Por ejemplo, si tenemos un bean con una propiedad firstName en el ámbito de la solicitud bajo el nombre customer, esta expresión EL representa el valor de la propiedad firstName del bean. ${customer.firstName} EL también hace que la información de la solicitud y la información general del contenedor esté disponible como un conjunto de variables implícitas: Variable param paramValues header headerValues cookie initParams pageContext pageScope requestScope sessionScope applicationScope
Descripción Map que mapea nombres de parámetros univaluados a String. Una colección de todos los valores de los parámetros de la solicitud como un array de valores string por cada parámetro. Una colección de todas las cabeceras de solicitud como un sólo valor string por cada cabecera. Una colección de todos los valores de cabecera de la solicitud como un array de valores string por cada cabecera. Una colección con todas las cookies de la solicitud en un sólo ejemplar de javax.servlet.http.Cookie por cada cokkie. Una colección de todos los parámetros de inicialización de la aplicación en un sólo valor string por cada parámetro. Un ejemplar de la clase javax.servlet.jspPageContext. Una colección de todos los objetos en el ámbito de la página. Una colección de todos los objetos en el ámbito de la solicitud. Una colección de todos los objetos en el ámbito de la sesión. Una colección de todos los objetos en el ámbito de la aplicación.
Las cinco primeras variables implícitas de la tabla nos ofrecen acceso a los valores de parámetros, cabeceras y cookies de la solicitud actual. Se muestra en el siguiente ejemplo, cómo acceder a un parámetro de solicitud llamado listType y a la cabecera . User-Agent: ${param.listType} ${header['User-Agent']} Este ejemplo se muestra para usar de un modo adecuado la sintaxis de array para la cabecera, porque el nombre incluye un guión; con la sintaxis de propiedad, sería interpretado como la expresión variable header.User menos el valor de una variable llamada Agent. La variable initParameter proporciona acceso a los parámetros de inicialización que se definen en el fichero web.xml de la aplicación. La variable pageContext tiene varias propiedades que proporcionan acceso al objeto servlet que representa la solicitud, la respuesta, la sesión y la aplicación, etc. Las cuatro últimas variables son colecciones que contienen todos los objetos de cada ámbito específico. Podemos usarlas para limitar la búsqueda de un objeto en sólo un ámbito en lugar de buscar en todos ellos, lo que está por defecto si no se especifica ningún ámbito. En otras palabras, si hay un objeto llamado customer en el ámbito de sesión, estas dos primeras expresiones encuentran el mismo objeto, pero la tercera vuelve vacía:
UNMSM- FISI
PAG. 5
TALLER DE PROYECTOS I
JSTL
${customer} ${sessionScope.customer} ${requestScope.customer}
Todas las acciones JSTL aceptan expresiones EL como valores de atributo, para todos los atributos excepto para var y scope, porque estos valores de atributo podrían usarse para chequear el tipo en el momento de la traducción en una futura versión. Hay un atributo de una acción JSTL adicional que no toma un valor de expresión EL, pero sólo se usa en la librería XML, por eso lo ignoraremos por ahora. Se pueden usar una o más expresiones EL en el mismo valor de atributo, y el texto fijo y las expresiones EL se pueden mezclar en el mismo valor de atributo: First name: <c:out value="${customer.firstName}" /> <c:out value="First name: ${customer.firstName}" /> Ahora veamos unos ejemplos de su uso: •
• •
Acceso a atributos de objetos Java en expresiones: ${user.firstName} = user.getFirstName() ${user.address.city} = user.getAddress().getCity() ${user.preferencesMap["shipping"]} = user.getPreferencesMap().get("shipping") ${user.preferencesList[0]} = user.getPreferencesList().get(0) Unificando el tratamiento de los operadores: . y [] ${user.firstName} es equivalente a ${user["firstName"]} ${user.preferencesMap["shipping"]} es equivalente a ${user.preferencesMap.shipping} Con operadoradores: [] ${user.preferencesMap["book.fiction"]} es equivalente a user.getPreferencesMap().get("book.fiction") ${user.preferencesMap[product.category]} es equivalente a user.getPreferencesMap().get(product.getCategory())
Instalación y configuración del JSTL La librería JSTL es distribuida como un conjunto de archivos JAR que simplemente tenemos que agregarlo en el classpath del contenedor de servlets. 1. Debemos usar un contenedor de servlets compatible con la ve rsión JSP 2.0 para usar el JSTL 1.1. El Apache Tomcat 5.0 [http://jakarta.apache.org/tomcat/] por ejemplo. En caso contrario, es posible usar el JSTL 1.0 en un contenedor que soporte por lo menos el JSP 1.2 y servlets 2.3. 2. Descargar la implementación JSTL de la página de proyecto Jakarta TagLibs [http://jakarta.apache.org/taglibs/binarydist.html]. La distribución binaria viene empaquetada como .zip o tar.gz. Desempaquete estos archivos en un directorio temporal. 3. Del directorio temporal, copie todos los archivos JAR que se encuentran en jakartataglibs/standard-1.0/lib al directorio /WEB-INF/lib de su aplicación Web. Esto incluirá los JAR específicos del JSTL así como también los otros JAR que depende de él. 4. Finalmente, importamos en las páginas JSP cada librería JSTL que la página necesitará. Eso lo hacemos agregando las directivas taglib apropiadas al inicio de la página JSP. Las directivas son: core: <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %> xml: <%@ taglib prefix="x" uri="http://java.sun.com/jstl/xml" %> fmt: <%@ taglib prefix="fmt" uri="http://java.sun.com/jstl/fmt" %> sql: <%@ taglib prefix="sql" uri="http://java.sun.com/jstl/sql" %>
UNMSM- FISI
PAG. 6
TALLER DE PROYECTOS I
JSTL
Ahora, creamos una página JSP y probamos algunas etiquetas simples para asegurarnos que la configuración del JSTL está bien hecha. CODE 1 2 3 4 5 6
<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %> Setting the value: "Hello World!"
Librerías englobada en el JSTL(Tags) JSTL 1.0 especifica un conjunto de librerías de etiquetas basadas en el API JSP 1.2. Hay cuatro librerías de etiquetas independientes, cada una contiene acciones personalizadas dirigidas a un área funcional específica. Esta tabla lista cada librería con su prefijo de etiqueta recomendado y la URI por defecto:
Descripción
•
Prefijo
Core XML Processing
c x
I18N & Formatting
fmt
Database Access
sql
La Librería Core
Contiene acciones para las tareas rutinarias, como incluir o excluir una parte de una página dependiendo de una condición en tiempo de ejecución, hacer un bucle sobre una colección de ítems, manipular URLs para seguimiento de sesión, y la correcta interpretación del recurso objetivo, así como acciones para importar contenido de otros recursos y redireccionar la respuesta a una URL diferente. JSTL core Area
UNMSM- FISI
Función
Tags
Prefijo
PAG. 7
TALLER DE PROYECTOS I
JSTL
Variable de soporte
remove set
Flow control
choose when otherwise forEach forTokens if
Core
URL management
import param redirect param url param
Miscellaneous
catch out
c
A continuación se describe cada tags según el tipo de función que desempeña: Variable de soporte Resumen de etiquetas remove
Elimina una variable (desde un ámbito particular, si se especifica). A continuación se muestra un ejemplo del remove:
O del cuerpo de la etiqueta
... Por ejemplo, los siguientes conjuntos una variable llamada EL BOOKID con el valor del parámetro de solicitud de quitar el nombre:
Control de flujo Resumen de etiquetas
choose
UNMSM- FISI
Es una etiqueta de condiciona simple que establece un contexto mutuamente excluyentes para las operaciones condicionales, marcado por <when> y
Por ejemplo, el código de ejemplo siguiente muestra cómo hacer que el texto sobre la base de un cliente de la categoría de miembros. ... ... ...
PAG. 8
TALLER DE PROYECTOS I
JSTL
Es una etiqueta condicional simple, que evalúa si la condición suministrada es verdadera y, opcionalmente, expone una variable booleana de secuencias de comandos que representan a la evaluación de esta condición. Un ejemplo de esta etiqueta se muestra a continuación: if ...
forEach
La etiqueta básica de iteración, acepta muchos tipos diferentes de subconjuntos de apoyo y otras funciones. Ejemplo: ... ...
forTokens
Itera más fichas, separados por el suministrado delimitado.
otherwise
Sub etiqueta de que sigue a la etiqueta<when> y funciona sólo si todas las condiciones previas para evaluar son «falsos». ...
when
Sub etiqueta de que incluye su cuerpo si su condición evaluada es 'verdadera.' ...
URL management Resumen de etiquetas import
Recupera un absoluto o relativo URL y expone su contenido, ya sea a la página, una cadena en 'var', o en un lector de 'varReader ».
param
Añade un parámetro para que contengan una "importación" de la etiqueta URL.
redirect
Redirige a una nueva URL.
url
Crea una URL con parámetros de consulta facultativa.
Varios Resumen de etiquetas catch
Captura cualquier Throwable que se produce en su cuerpo y, opcionalmente, se expone.
out
Al igual que <% = ... >, Pero para las expresiones.
UNMSM- FISI
PAG. 9
TALLER DE PROYECTOS I
•
JSTL
La Librería XML
Contiene acciones para procesamiento XML, incluido validar un documento XML y transformarlo usando XSLT. También proporciona acciones para extraer parte de un documento XML validado, hacer bucles sobre un conjunto de nodos, y procesamiento condicional basado en valores de nodos. Area
Función Núcleo
Etiqueta
Prefijo
out parse set
choose when XML Flujo de control otherwise forEach if Transformación
x
transform param
A continuación se describe cada etiqueta según el tipo de función que desempeña: Núcleo Resumen de etiquetas out
Al igual que <% = ... >, Pero para las expresiones XPath.
parse
Analiza el contenido en XML de 'fuente' atributo o 'cuerpo'
set
Guarda el resultado de una expresión XPath evaluada en un 'ámbito'
Flujo de Control Resumen de etiquetas choose
Es una etiqueta de condiciona simple que establece un contexto mutuamente excluyentes para las operaciones condicionales, marcado por <when> y
if
Etiqueta XML condicional, que evalua su cuerpo, si la expresión XPath suministrados es "verdadero" ,como un booleano.
forEach
Es una etiqueta de iteración XML .
otherwise
Sub etiqueta de que sigue a la etiqueta<when> y funciona sólo si todas las condiciones previas para evaluar son «falsos».
when
Sub etiqueta de que incluye su cuerpo si su condición evaluada es 'verdadera.'
La página JSP bookcatalog.jsp utiliza la etiqueta foreach para mostrar todos los libros figura BookList en la forma siguiente: Code: <x:forEach var="book" select="$applicationScope:booklist/books/*"> <x:out select="$book/@id"/>
UNMSM- FISI
PAG. 10
TALLER DE PROYECTOS I
JSTL
= <strong><x:out select="$book/title"/> |
<em> <x:out select="$book/firstname"/> <x:out select="$book/surname"/> |
Transformación Resumen de etiquetas param
Añade un parámetro para que contenga una "transformar" de la etiqueta de transformadores
transform
Lleva a cabo una transformación de un documento XML fuente y una hoja de estilos XSLT.
•
La Librería I18N & Formatting fmt
Comprende la internacionalización y formato de valores como de moneda y fechas. Las grandes sites normalmente necesitan complacer a los visitantes de todo el mundo, y servir el contenido sólo en un idioma no es suficiente. Para desarrollar una site que proporcione una elección de idiomas, tenemos dos opciones: • •
Escribir un conjunto de páginas para cada idioma. Escribir un conjunto compartido de páginas que ponga el contenido en diferentes idiomas desde fuentes externas.
Resumen de etiquetas Establece la localización por omisión para el especificado ámbito de aplicación. Esto anulará la browserbased local. setLocale bundle
UNMSM- FISI
Establece el contexto de localización, basados en especificada en el paquete de recursos, para ser utilizado dentro de
PAG. 11
TALLER DE PROYECTOS I
JSTL
el cuerpo el contenido de esta etiqueta. Crea y almacena en un alcance variable, un contexto de localización basado en el especificado paquete de recursos. setBundle
message
Parece un mensaje localizado en un paquete de recursos. Esta etiqueta puede contener anidadas etiquetas para especificar formato del mensaje la sustitución de valores. El mensaje resultante se imprime o almacenada en un alcance variable. Supplies a parameter for message format substitution in a containing
param
tag. Parameters are substituted in sequential order.
Encarga a utilizar JSTL una codificación de caracteres (véase http://www.iana.org/assignments/character-sets) requestEncoding para decodificar parámetros de solicitud. Omitir un valor indica a utilizar la detección automática de la correcta codificación.
Formato de Acciones Las acciones de formato analizan los números, monedas, porcentajes, fechas y horas. Resumen de etiquetas timeZone
Ajusta el tiempo especificado, zonas que se aplicarán al cuerpo anidado contenido. El siguiente ejemplo muestra que el tiempo zona por esta acción sólo ha anidado visibilidad. <jsp:useBean id="now" class="java.util.Date"/> Pacific Time:
UNMSM- FISI
PAG. 12
TALLER DE PROYECTOS I
JSTL
Local Time: Ajusta el tiempo especificado en una zona, nombre de un alcance variable o utilizando el intervalo de tiempo predeterminado Nombre de zona var si no se especifica. setTimeZone
formatNumber
Mountain Time: Formatos de un número, moneda, o el porcentaje en un local con tacto y sensibilidad. El valor es el formato impreso o almacenado en una scoped variable.
Formato de Fechas Fechas y formatos son analizados utilizando el y acciones que comparten las siguientes atributos en común. Resumen de etiquetas Formatos de fecha y/o el tiempo en un local con tacto y sensibilidad. El valor es el formato impreso o almacenado en un alcance variable. formatDate Analiza una cadena que representa una fecha y/o tiempo en un local con tacto y sensibilidad. El valor es analizado impreso o almacenado en un alcance variable. parseDate
•
Acceso a la Base de Datos (SQL)
La etiqueta SQL se dispone para llevar a cabo acciones bases de datos transaccionales, las consultas y actualizaciones, tener acceso fácilmente a los resultados de una consulta. Comprende el acceso a base de datos. Un sujeto de controversia es la inclusión en JSTL de acciones para acceder a bases de datos. Alguna gente ve esto como una mala práctica y argumenta que todos los accesos a bases de datos se deberían realizar desde componentes Java puros en una aplicación basada en MVC
UNMSM- FISI
PAG. 13
TALLER DE PROYECTOS I
JSTL
en lugar de desde página JSP. Resumen de etiquetas Realiza una consulta de base de datos (por ejemplo, select). La consulta se debería esperar para volver un conjunto de resultados. Esta acción puede incluir cuerpo que contiene el contenido real de cadena de consulta, así como <sql:param> y <sql:dateParam> etiquetas de parámetro de sustitución. Si el cuerpo contiene la consulta SQL, debe aparecer antes de cualquier parámetro etiquetas anidadas. query
<sql:query var="users"> SELECT * FROM users WHERE last_name = "Burdell"
Realiza una base de datos de insertar, actualizar, eliminar o otra declaración (por ejemplo, una declaración DDL), que no devuelve ningún resultado. Esta acción puede incluir cuerpo que contiene el contenido real de actualización de la cadena, así como etiquetas para <sql:param> parámetro de sustitución. Al igual que <sql:query>, el <sql:param> etiquetas debe ocurrir después de la declaración de SQL si es que figura en la etiqueta.
update <sql:update> cuerpo. <sql:update var="updateCount"> UPDATE users SET first_name="William" WHERE first_name = "Bill"
transaction
Establece una base de datos de transacción para <sql:query> y <sql:update> etiquetas que figuran en esta etiqueta del cuerpo. Es decir, todos los SQL acciones contenidas en el cuerpo de esta etiqueta será tratada como una única transacción atómica. La transacción se ha comprometido sólo si todas las declaraciones éxito. Si alguno de los contenidos de SQL acciones causan una excepción, la transacción se deshace. Nota: esta acción antes de restablecer el "auto de cometer" ajuste después de su realización. <sql:transaction> <sql:update sql="DELETE users WHERE user_name='bsiggelkow'"/> <sql:update sql="INSERT INTO users VALUES ('billsigg','Bill','Siggy')"/> Crea y almacena en una variable alcance una fuente de datos SQL. Esta etiqueta no puede tener un cuerpo. O bien la fuente de datos o URL atributo debe ser especificado.
setDataSource
param
UNMSM- FISI
<sql:setDataSource var="testDB" url="jdbc:mysql://localhost/test, com.mysql.jdbc.Driver"/> <sql:query var="users" dataSource="${testDB}"> SELECT * FROM users Suplentes parámetros en SQL declaración preparada marcadores de posición
PAG. 14
TALLER DE PROYECTOS I
JSTL
("?"). Esta acción sólo se puede anidar dentro de <sql:query> o <sql:update> etiquetas. Si la etiqueta especifica que remite el SQL en el cuerpo, cualquier <sql:param> etiquetas debe aparecer después de la SQL. Los parámetros son sustituidos en orden secuencial. Bill <sql:query var="users"> SELECT user_name, last_name FROM users WHERE first_name = ? <sql:param value="${firstName}"/> Suplentes hora, fecha, hora o los parámetros en SQL declaración preparada marcadores de posición. Esta acción sólo se puede anidar dentro de <sql:query> o <sql:update> etiquetas. Los parámetros son sustituidos en orden secuencial.
dateParam
<sql:query var="postWarBabies"> SELECT user_name FROM user_profile WHERE birth_date > ? <sql:dateParam value="${ww2End}" type="date"/>
Referencias
•
http://www.programacion.com/java/tutorial/jstl1/2/
•
http://www.programacion.com/java/tutorial/jstl1/3/
•
http://java.sun.com/j2ee/1.4/docs/tutorial/doc/JSTL8.html
•
http://java.sun.com/products/jsp/jstl/1.1/docs/tlddocs/index.html
UNMSM- FISI
PAG. 15