1

我在我的 mvc4 项目中使用 RavenDB 将类对象存储到 RavenDB 时它工作正常,但是在执行选择操作时会引发错误:

你调用的对象是空的

所有查询

RavenbaseController.cs

public class RavenBaseController : Controller
{
   public IDocumentSession RavenSession { get; protected set; }

   protected override void OnActionExecuting(ActionExecutingContext filterContext)
   {
      RavenSession = MvcApplication.Store.OpenSession("ravendbtesting");
   }

   protected override void OnActionExecuted(ActionExecutedContext filterContext)
   {
      if (filterContext.IsChildAction)
         return;

      using (RavenSession)
      {
         if (filterContext.Exception != null)
             return;

         if (RavenSession != null)
             RavenSession.SaveChanges();
      }
   }
}

激活.cs

public class Activation : RavenBaseController
{
    public string tokenid { get; set; }

    public bool validate(string tid)
    {
        var query = from u in RavenSession.Query<Register>() where u.TokenId == tid select u;

        foreach (var v in query)
        {
            v.IsApproved = true;
        }

        RavenSession.SaveChanges();
        return true;
    }
}

尝试的查询:

var results = from u in RavenSession.Query<Register>()
    where u.TokenId == tid
    select u;

var query= RavenSession.Query<Register>()
                                     .Where(x => x.TokenId == tid)
                                      .ToList(); 

我不明白为什么它不起作用我是 RavenDB 的新手

更新

如果从控制器运行,所有查询都可以正常工作,但如果从类文件运行,则会出现错误“对象引用未设置为对象的实例”

4

1 回答 1

0

如果您尝试实例化var ctrl = new Activation();并执行此操作ctrl.validate(x);,它将无法正常OnActionExecuting运行。该函数在处理请求时由 MVC 框架自动调用,而不是在手动测试时。

由于 MVC 无论如何都会在每个请求上实例化一个新控制器,因此您应该将 RavenSession 初始化移动到构造函数,因为您似乎没有在请求上下文中使用任何信息:

public class RavenBaseController : Controller
{
   public IDocumentSession RavenSession { get; protected set; }

   public RavenBaseController()
   {
      RavenSession = MvcApplication.Store.OpenSession("ravendbtesting");
   }

   protected override void OnActionExecuted(ActionExecutedContext filterContext)
   {
      if (filterContext.IsChildAction)
         return;

      using (RavenSession)
      {
         if (filterContext.Exception != null)
             return;

         if (RavenSession != null)
             RavenSession.SaveChanges();
      }
   }
}

更好的方法是使用依赖注入将会话作为构造函数参数传递,但上述方法应该适合您。

于 2014-01-10T20:41:02.947 回答