Pregunta

descripción del problema: Este modelo funciona bien con un usuario a la vez. Tan pronto como llegue a múltiples usuarios a la vez, consigo un grave de los errores relacionados con el cierre de mi no SqlDataReader. Cuando apago la carga diferida de esta manera:

persistenceModel.Conventions.OneToManyConvention = (prop => prop.SetAttribute ( "perezosa", "falso"));

Está bien, pero el rendimiento es lento. Esto utiliza MVC Beta 1

¿Alguna idea?

A continuación tengo un fragmento de mi ASAX global, así como mi código inialization SessionFactory.

*********** ESTO ES EN MI GLOBAL.ASAX ********

public class MvcApplication : NinjectHttpApplication
{
    public static IKernel Kernel { get; set; }

    protected override void RegisterRoutes(RouteCollection routes)
    {
        routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
        //routes.IgnoreRoute("WebServices/*.asmx");

        routes.MapRoute("CreateCategoryJson", "Admin/CreateCategoryJson/{categoryName}");
        routes.MapRoute("User", "Admin/User/{username}", new { controller="Admin", action="user" });

        routes.MapRoute(
            "Default",                                              // Route name
            "{controller}/{action}/{id}",                           // URL with parameters
            new { controller = "Home", action = "Index", id = "" }  // Parameter defaults
        );

    }

    protected void Session_Start(object sender, EventArgs e)
    {
        if (Session["rSkillsContext"] == null)
        {
            string logonName = this.User.Identity.Name.Replace("NUSOFTCORP\\", string.Empty);
            rSkillsContext context = new rSkillsContext(logonName);
            Session.Add("rSkillsContext", context);
        }
    }

    protected override IKernel CreateKernel()
    {
        log4net.Config.XmlConfigurator.Configure();
        Kernel = new StandardKernel(new RepositoryModule(), new AutoControllerModule(Assembly.GetExecutingAssembly()), new Log4netModule());
        return Kernel;
    }
}

***** Este es mi NHibernateHelper.cs ******

    private ISessionFactory CreateSessionFactory()
    {
        var configuration = MsSqlConfiguration
                                .MsSql2005
                                .ConnectionString.FromConnectionStringWithKey("ConnectionString")
                                .ShowSql()
                                .Raw("current_session_context_class", "web")
                                .ConfigureProperties(new Configuration());

        var persistenceModel = new PersistenceModel();

        persistenceModel.Conventions.GetForeignKeyName = (prop => prop.Name + "ID");
        persistenceModel.Conventions.GetForeignKeyNameOfParent = (prop => prop.Name + "ID");
        // HACK: changed lazy loading
        persistenceModel.Conventions.OneToManyConvention = (prop => prop.SetAttribute("lazy", "false"));

        persistenceModel.addMappingsFromAssembly(Assembly.Load(Assembly.GetExecutingAssembly().FullName));
        persistenceModel.Configure(configuration);

        return configuration.BuildSessionFactory();
    }
¿Fue útil?

Solución

Parece que no disponía de su sesión correctamente (que tenía el mismo error con Ninject y NHibernate hace un mes). Se debe iniciarse al comienzo de solicitud y debe ser dispuesta en el extremo. ¿Podrían presentar piezas de código en el que empiezan y disponer su sesión de NHibernate?

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top