Diferencia entre revisiones de «Dynamic Query en Liferay»

De Dos Ideas.
Saltar a: navegación, buscar
Línea 47: Línea 47:
  
 
* [http://www.liferay.com/es/community/wiki/-/wiki/Main/Queries+2%3A+DynamicQuery+API Wiki Liferay]
 
* [http://www.liferay.com/es/community/wiki/-/wiki/Main/Queries+2%3A+DynamicQuery+API Wiki Liferay]
 +
 +
[[Category:Liferay Dynammic Query]]

Revisión del 12:38 2 ago 2013

Liferay, a partir de la versión 5.1, proporcionar acceso a la API de consulta dinámica de Hibernate. Esto permite realizar consultas complejas sobre las estructuras o lista dinámicas que existan en el portal.

Dynamic Query + Velocity

En este ejemplo se muestra como implementar las consultas dinámicas en un Template de una Lista dinámica. La consulta obtiene los 20 primeros registros del usuario registrado ordenados de forma descendentepor fecha de modificación.

    1. Obtiene el userId.
  1. set($userId = $request.get("theme-display").get("user-id"))
    1. Obtiene el servicio para ejecutar las consultas dinamicas.
  1. set ($ddlLocalService = $serviceLocator.findService('com.liferay.portlet.dynamicdatalists.service.DDLRecordLocalService'))
    1. Obtiene el id de la lista.
  1. set ($recordSetId = $getterUtil.getLong($reserved_record_set_id.data, 0))
    1. Obtiene el tipo de respuesta para la consulta dinamica.
  1. set ($DDLrecordClass = $portal.getClass().forName("com.liferay.portlet.dynamicdatalists.model.DDLRecord"))
    1. Utilidad para armar consultas dinamicas.
  1. set ($dqfu = $portal.getClass().forName("com.liferay.portal.kernel.dao.orm.DynamicQueryFactoryUtil"))
    1. Utilidad para agregar ordenamiento a la consulta dinamica.
  1. set ($ofu = $portal.getClass().forName("com.liferay.portal.kernel.dao.orm.OrderFactoryUtil"))
    1. Restricciones
  1. set ($rfu = $portal.getClass().forName("com.liferay.portal.kernel.dao.orm.RestrictionsFactoryUtil"))
    1. Query
  1. set ($q = $dqfu.forClass($DDLrecordClass))
  2. set ($V = $q.add($rfu.eq("recordSetId", $getterUtil.getLong($recordSetId))))
  3. set ($V = $q.add($rfu.eq("userId", $getterUtil.getLong($userId))))
  4. set ($V = $q.addOrder($ofu.desc("modifiedDate")))
  5. set ($records = $ddlLocalService.dynamicQuery($q,0,20))
  1. foreach($record in $records)
   #set ($titulo = $record.getField("Titulo").getValue())
   #set ($link = $record.getField("Link").getValue())
   
       <a href="$link">$titulo</a> 
  1. end

Ver Tambien