martes, 6 de noviembre de 2012

WF.NET. y WCF.NET. "ERROR: No se puede encontrar la cadena de conexión para el nombre de conexión 'ApplicationServerWorkflowInstanceStoreConnectionString'."



 PROBLEMA 

Al acceder a un Web Service de Flujo de Trabajo (.xamlx) en IIS con AppFabric habiendo establecido el almacén de persistencia de flujo de trabajo por defecto (defaultSqlPersistenceStore) se obtiene el siguiente error "ERROR: No se puede encontrar la cadena de conexión para el nombre de conexión 'ApplicationServerWorkflowInstanceStoreConnectionString'."


 SOLUCIÓN 

Hay que poner la propiedad  "Habilitar aplicaciones de 32 bits" (Enable 32-bit application) del grupo de aplicaciones (Application Pools) correspondiente al Web Service que falla, a False.


Para cambiar dicha propiedad en IIS7, localiza 'Application Pools' en el 'IIS Manager':




Entra en el grupo de aplicaciones correspondiente al servicio que está fallando:





Cambia el valor de la propiedad 'Enable 32-bit Applications' a False.







martes, 2 de octubre de 2012

ADO.NET Entity Framework. Error "... mientras se actualizaban las entradas." debido a problema en la propiedad StoreGeneratedPattern


 PROBLEMA 

Se produce el error de abajo al depurar una aplicación .NET 4.0 VS2010 con modelo de datos ADO.NET Entity Framework, teniendo un atributo clave de entidad con la propiedad StoreGeneratedPattern con valor "Identity". Utilizamos StoreGeneratedPattern= "Identity" cuando dicho atributo clave se mapea con un campo de la tabla definido como clave primaria y que cuyo valor se establece automáticamente mediante un trigger en la base de datos. Por lo que no deseamos que el modelo ADO.NET establezca el valor del atributo.

System.ServiceModel lanza la siguiente excepción:
"Se produjo un error mientras se actualizaban las entradas. Vea la excepción interna para obtener detalles."

 SOLUCIÓN 

Parece que se debe a un defecto bug en el ADO.NET Entity Framework.

El problema radica en que el diseñador de modelos Entity Framework no establece automáticamente la propiedad StoreGeneratedPattern= "Identity" en la sección del modelo de almacenamiento (SSDL) mientras que sí lo hace en el modelo conceptual (CSDL). Esto se puede comprobar y corregir en el archivo EDMX del modelo, editándolo con el editor de xml.

En el siguiente ejemplo observamos como en el diseñador de modelos hemos establecido el atributo id de la entidad TarjetaMovil con la propiedad StoreGeneratedPattern= "Identity".


Si editamos el archivo .edmx correspondiente a dicho modelo observarermos los siguiente, siendo TEL_TARJETAS_MOVIL la tabla que se asigna a la entidad TarjetaMovil. La definicion de StoreGeneratedPattern aparece en su sitio en el modelo CSDL pero no en el modelo SSDL.
 
<edmx:StorageModels>
        .....
<EntityType Name="TEL_TARJETAS_MOVIL">
<Key><PropertyRef Name="ID" /></Key>
<Property Name="ID" Type="number" Nullable="false" />
        .....
        .....
<edmx:ConceptualModels>
<Key><PropertyRef Name="id" /></Key>
<EntityType Name="TarjetaMovil">
        .....
<Property Type="Int32" Name="id" Nullable="false" annotation:StoreGeneratedPattern="Identity" >


Para resolver el problema bastará con añadir StoreGeneratedPattern="Identity" (ATENCIÓN: sin incluir annotation:) en el lugar correspondiente del modelo de almacenamiento como se ve a continuación:

<edmx:StorageModels>
        .....
<EntityType Name="TEL_TARJETAS_MOVIL">
<Key><PropertyRef Name="ID" /></Key>
<Property Name="ID" Type="number" Nullable="false" StoreGeneratedPattern="Identity" />


martes, 11 de septiembre de 2012

VB.NET ¿Como ordenar una lista genérica de objetos sin modificar la clase a la que pertenecen?


Para ello es necesario que la clase de los objetos a ordenar implementen la interfaz IComparable. Si no podemos o no deseamos modificar la clase de los objetos en cuestión y esta no implementa el interfaz IComparable, podremos usar el método Sort, al cual se le pasa como parámetro una función delegada con el método de comparación. En el método de comparación utilizaremos algún atributo de la clase original cuyo tipo implemente el método CompareTo.


En el ejemplo deseamos ordenar una lista genérica de objetos de la clase 'Persona', para ello utilizaremos el atributo 'dni' que es tipo integer.

Código en VB.NET:
Dim listaPersonas As List(Of ClasePersona)

----

listaPersonas.Sort(Function(persona1 As ClasePersona, persona2 As ClasePersona)
    
persona1.dni.CompareTo(persona2.dni))

miércoles, 25 de enero de 2012

En Visual Studio ha desaparecido la opción "release" en "configuraciones de soluciones"


 PROBLEMA 

En Visual Studio 2005, 2008 o 2010 ha desaparecido la opción "release" en el desplegable de "configuraciones de soluciones" en una solución.

Sólo aparece la opción "debug" en el desplegable de "configuraciones de soluciones" pero no la opción "release".




 SOLUCIÓN 

Editar el archivo .sln de la solución con un editor de texto. Comprobar que aparece la línea resaltada abajo y en caso contrario añadirla a mano.


GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
Release|Any CPU = Release|Any CPU
EndGlobalSection