gpt4 book ai didi

c# - SimpleData 复杂连接和投影到 poco 类型

转载 作者:行者123 更新时间:2023-11-30 17:16:17 26 4
gpt4 key购买 nike

我开始更认真地使用 Simple.Data 并且有以下情况似乎不起作用,我无法理解为什么不(可能是我一直盯着看的愚蠢的东西几个小时)。

基本数据库结构:

事件<->事件_加入<->位置

(使用连接表的多对多关系商店、事件和位置应该非常简单。假设彩弹射击事件可以在布里斯托尔、巴斯等地进行。旅行基本上是一个版本问题(男/女/etc) 用于内容/样式。)

简单的数据查询:

return _database.Activity.Query()
.Join(_database.Activity_Join).On(_database.Activity.ID_Activity == _database.Activity_Join.ID_Activity)
.Join(_database.Location).On(_database.Activity_Join.ID_Location == _database.Location.ID_Location)
.Where(_database.Activity.ID_trip == idTrip &&
_database.Activity.Activity_Time == 'D' &&
_database.Activity.Is_Public == true)
.Select(
_database.Activity.ID_Activity
, _database.Location.ID_Location
, _database.Activity.ID_Trip
, _database.Activity.Activity_Name
, _database.Activity.Adrenaline_Factor
, _database.Activity.Relaxation_Factor
, _database.Activity.Fun_Factor
, _database.Activity.Activity_Description
, _database.Activity.Activity_Extra_Info
, _database.Activity.Activity_Time
, _database.Activity.Activity_Price
, _database.Activity.Activity_Duration
, _database.Activity.Activity_Image
, _database.Activity.Is_Public).Cast<Activity>();

POCO:

using System;

namespace Blah.Models.POCOs
{
public class Activity
{
public Guid ID_Activity { get; set; }
public Guid ID_Location { get; set; }
public Guid ID_Trip { get; set; }
public string Activity_Name { get; set; }
public int Adrenaline_Factor { get; set; }
public int Relaxation_Factor { get; set; }
public int Fun_Factor { get; set; }
public string Activity_Description { get; set; }
public string Activity_Extra_Info { get; set; }
public string Activity_Time { get; set; }
public decimal Activity_Price { get; set; }
public string Activity_Duration { get; set; }
public string Activity_Image { get; set; }
public bool Is_Public { get; set; }
}
}

查询的目的是获取每次旅行的事件和 ID_Location guid 上的标签,以便能够找出事件发生的地点。在我的代码中,我将位置列表保存在内存中,因此出于其他一些原因,我将使用 LINQ 而不是 DB。

问题是它不会转换为 POCO!错误和堆栈跟踪是:

Object reference not set to an instance of an object.

at Simple.Data.Ado.Joiner.<GetJoinClauses>d__a.MoveNext()
at System.Linq.Enumerable.<ConcatIterator>d__71`1.MoveNext()
at System.Linq.Enumerable.<ConcatIterator>d__71`1.MoveNext()
at System.Linq.Enumerable.<ConcatIterator>d__71`1.MoveNext()
at System.Linq.Enumerable.<ConcatIterator>d__71`1.MoveNext()
at System.Linq.Enumerable.<DistinctIterator>d__81`1.MoveNext()
at System.String.Join(String separator, IEnumerable`1 values)
at Simple.Data.Ado.QueryBuilder.HandleJoins()
at Simple.Data.Ado.QueryBuilder.Build(SimpleQuery query, IEnumerable`1& unhandledClauses)
at Simple.Data.Ado.AdoAdapter.RunQuery(SimpleQuery query, IEnumerable`1& unhandledClauses)
at Simple.Data.SimpleQuery.Run()
at Simple.Data.SimpleQuery.Cast[T]()
at System.Dynamic.UpdateDelegates.UpdateAndExecute1[T0,TRet](CallSite site, T0 arg0)
at blahh.Models.Site.SitemapGenerator.GetDayActivitiesPerTrip(Guid idTrip) in D:\Projects\blah\blahh\Models\Site\SitemapGenerator.cs:line 39
at blahh.Models.Site.SitemapGenerator.Generate() in D:\Projects\blah\blahh\Models\Site\SitemapGenerator.cs:line 80
at blahh.Controllers.AdminController.Generate_Sitemap() in D:\Projects\blah\blahh\Controllers\AdminController.cs:line 1360
at lambda_method(Closure , ControllerBase , Object[] )
at System.Web.Mvc.ActionMethodDispatcher.Execute(ControllerBase controller, Object[] parameters)
at System.Web.Mvc.ReflectedActionDescriptor.Execute(ControllerContext controllerContext, IDictionary`2 parameters)
at System.Web.Mvc.ControllerActionInvoker.InvokeActionMethod(ControllerContext controllerContext, ActionDescriptor actionDescriptor, IDictionary`2 parameters)
at System.Web.Mvc.ControllerActionInvoker.<>c__DisplayClass15.<InvokeActionMethodWithFilters>b__12()
at System.Web.Mvc.ControllerActionInvoker.InvokeActionMethodFilter(IActionFilter filter, ActionExecutingContext preContext, Func`1 continuation)

最佳答案

我刚刚向 Simple.Data 套件添加了一个测试(以连接术语),它与您在那里所做的完全一样,不幸的是(为了回答您的问题),它通过了。

您使用的是最新版本吗?我最近将 0.9.5 推送到 NuGet,所以也许更新到那个会有帮助?如果做不到这一点,我们可以将其移交给 Google Group,我会帮助您解决。

关于c# - SimpleData 复杂连接和投影到 poco 类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7324570/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com