Trabajando con los campos de tipo time desde los webservices se da el caso que la hora no se graba correctamente. Esto es por la configuracion del archivo CustomSettings.config del servidor de Web Service.
No voy a hacer una entrada detallada porque esta todo perfectamente explicado en este blog. Solamente saber, que para evitarnos quebraderos de cabeza, poner que la hora de los web services es la misma del servidor con la siguiente entrada:
<add key="WebServicesDefaultTimeZone" value="Server Time Zone"></add>
jueves, 26 de diciembre de 2013
jueves, 19 de diciembre de 2013
Añadir el modo de autenticacion básico a nuestro Servidor de Informes
Recientemente he estado trabajando en un proyecto que consistia en crear una pagina web en php y javascript que mediante ajax consumia servicios web de Navision. Surgía la necesidad de consumir web service de Reporting Service desde php para integrar los informes dentro de la web. No vamos a explicar como se hace en este post porque esta todo en este link .
Lo que si vamos a explicar es como añadir el modo de autenticacion básico a nuestro servidor de informes para que funcione los objetos de php.
En la carpeta de instalación de Reporting Services que esta en :
C:\Program Files\Microsoft SQL Server\MSRS10_50.MSSQLSERVER\Reporting Services\ReportServer
Hay un archivo llamado rsreportserver.config. Dentro del tag AuthenticationTypes añadir lo siguiente:
Recordad que primero hay que parar los servicios del servidor de informes porque si no no dehjará modificar el fichero.
Lo que si vamos a explicar es como añadir el modo de autenticacion básico a nuestro servidor de informes para que funcione los objetos de php.
En la carpeta de instalación de Reporting Services que esta en :
C:\Program Files\Microsoft SQL Server\MSRS10_50.MSSQLSERVER\Reporting Services\ReportServer
Hay un archivo llamado rsreportserver.config. Dentro del tag AuthenticationTypes añadir lo siguiente:
Recordad que primero hay que parar los servicios del servidor de informes porque si no no dehjará modificar el fichero.
miércoles, 11 de diciembre de 2013
Obtener el texto de un option en Reporting Services y mediante WEB SERVICES
Una vez tenemos nuestro ensamblado con los web services en sql (Ver post
Consumir Web Services de Navision desde Reporting Services), vamos a utilizarlo para transformar los campos options en el valor de texto correspondiente. Para eso utilizamos una funcion en navision que le paso una tabla y un campo y nos devuelve una lista de las opciones separadas por coma.Me he creado una función llamada ObtenerWS que le paso un id y un texto.
El id 1 me devuelve los options de la tabla y el campo deseado (En el ejemplo Tabla 50045 campo 3).
Consumir Web Services de Navision desde Reporting Services), vamos a utilizarlo para transformar los campos options en el valor de texto correspondiente. Para eso utilizamos una funcion en navision que le paso una tabla y un campo y nos devuelve una lista de las opciones separadas por coma.Me he creado una función llamada ObtenerWS que le paso un id y un texto.
El id 1 me devuelve los options de la tabla y el campo deseado (En el ejemplo Tabla 50045 campo 3).
Con la funcion StringSplit lo transformo en una tabla:
SELECT *
FROM
StringSplit(([NAVSQL].[dbo].[ObtenerWS] (1,'50045|3')), ',', null)
El
resultado del select anterior es este:
Esto lo
pongo en un report como Dataset aparte.
Luego
hago la consulta normal (A la Tabla 50045) en otro Dataset que me devuelve el campo option como
integer. Para transformarlo al valor de texto en la casilla en vez de poner
el campo option como integer, hay que poner lo siguiente:
=Lookup(Fields!Concepto.Value,Fields!ID.Value,Fields!NOMBRE.Value,"Concepto")
Donde:
Fields!Concepto.Value
= El campo option en integer.
Fields!ID.Value
= Al campo option en integer en el dataset de la lista de options
Fields!NOMBRE.Value
= Al campo String que contiene la descripcion del option en el dataset de la
lista de options
"Concepto" = El nombre del Dataset de apoyo.
Y
listo. Asi solo llamas a los web services una vez (Para cargar la tabla de
options) y no para cada uno de los resultados.
miércoles, 4 de diciembre de 2013
Pasar un valor MultiValue por URL a Reporting Services
Para pasar un valor múltiple a Reporting Services por URL se hace de la siguiente manera:
&Parametro_Mio=Valor1&Parametro_Mio=Valor2&Parametro_Mio=Valor3
&Parametro_Mio=Valor1&Parametro_Mio=Valor2&Parametro_Mio=Valor3
Suscribirse a:
Entradas (Atom)