- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在评估 ServiceStack 以确定它是否适用于通用 REST 服务器构建目的,并且我正在尝试扩展 Northwind 演示,我已在本地更新该演示以使用 ServiceStack 4.0.44。我调整过的代码在 Bitbucket 上 here , 从 git 转储到 hg,然后用我自己的 changes添加。
我的代码和上游serviceStack.Examples northwind demo的区别在于增加了以下内容:
A .../date/Route 被添加到订单的 ServiceModel.Operations 对象中:
namespace ServiceStack.Northwind.ServiceModel.Operations
{
...
[Route("/orders")]
[Route("/orders/date/{ByDate}")] // ADDED!
[Route("/orders/page/{Page}")]
[Route("/customers/{CustomerId}/orders")]
public class Orders
{
public int? Page { get; set; }
public DateTime? ByDate { get; set; } // ADDED!
public string CustomerId { get; set; }
}
然后将这种情况的处理程序添加到服务中,该服务在运行时因奇怪的 LINQ 故障而爆炸:从范围引用的类型为“ServiceStack.Northwind.ServiceModel.Types.Order”的变量“o”' ',但未定义...
Source = System.Core
namespace ServiceStack.Northwind.ServiceInterface
{
public class OrdersService : Service
{
private const int PageCount = 20;
public object Get(Orders request)
{
List<Order> orders = null;
if (request.ByDate.HasValue)
{ // date provided
// broken LINQ #1 -- EXCEPTION HERE AT RUNTIME!
orders = Db.Select<Order>(order => order.Where<Order>(o => o.OrderDate.Value.Date == request.ByDate.Value.Date ));
/*
broken LINQ #2
orders =
Db.Select(
Db.From<Order>().
Where(o => (o != null) && o.OrderDate.HasValue && (request.ByDate.Value.Date == o.OrderDate.Value.Date)
)
);
*/
}
else if (request.CustomerId.IsNullOrEmpty())
{
orders = Db.Select<Order>(order => order.OrderByDescending(o => o.OrderDate))
.Skip((request.Page.GetValueOrDefault(1) - 1) * PageCount)
.Take(PageCount)
.ToList();
}
else
{
orders = Db.Select<Order>(order => order.Where(o => o.CustomerId == request.CustomerId));
}
if (orders.Count == 0)
该异常要么表明我不知道如何编写 LINQ 表达式来按日期查询,要么可能表明 SQLite 的 ORM 中存在内部错误,或者整个框架中存在错误,或者我正在做出了点问题。
当我尝试按 DateTime 值进行查询时,Firebird 提供程序也会重现类似的运行时崩溃,因此它可能是 SQLite 和 Firebird ORMLite 提供程序中的错误。
System.InvalidOperationException was unhandled by user code
HResult = -2146233079
Message = variable 'o' of type 'ServiceStack.Northwind.ServiceModel.Types.Order' referenced from scope '', but it is not defined
Source = System.Core
StackTrace:
at System.Linq.Expressions.Compiler.VariableBinder.Reference(ParameterExpression node, VariableStorageKind storage)
at System.Linq.Expressions.Compiler.VariableBinder.VisitParameter(ParameterExpression node)
at System.Linq.Expressions.ParameterExpression.Accept(ExpressionVisitor visitor)
at System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
at System.Linq.Expressions.ExpressionVisitor.VisitMember(MemberExpression node)
at System.Linq.Expressions.MemberExpression.Accept(ExpressionVisitor visitor)
at System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
at System.Linq.Expressions.ExpressionVisitor.VisitMember(MemberExpression node)
at System.Linq.Expressions.MemberExpression.Accept(ExpressionVisitor visitor)
at System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
at System.Linq.Expressions.Compiler.VariableBinder.VisitUnary(UnaryExpression node)
at System.Linq.Expressions.UnaryExpression.Accept(ExpressionVisitor visitor)
at System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
at System.Linq.Expressions.ExpressionVisitor.Visit(ReadOnlyCollection`1 nodes)
at System.Linq.Expressions.Compiler.VariableBinder.VisitLambda[T](Expression`1 node)
at System.Linq.Expressions.Expression`1.Accept(ExpressionVisitor visitor)
at System.Linq.Expressions.ExpressionVisitor.Visit(Expression node)
at System.Linq.Expressions.Compiler.VariableBinder.Bind(LambdaExpression lambda)
at System.Linq.Expressions.Compiler.LambdaCompiler.Compile(LambdaExpression lambda, DebugInfoGenerator debugInfoGenerator)
at ServiceStack.OrmLite.SqlExpression`1.VisitMemberAccess(MemberExpression m)
at ServiceStack.OrmLite.SqlExpression`1.Visit(Expression exp)
at ServiceStack.OrmLite.SqlExpression`1.VisitBinary(BinaryExpression b)
at ServiceStack.OrmLite.SqlExpression`1.Visit(Expression exp)
at ServiceStack.OrmLite.SqlExpression`1.VisitBinary(BinaryExpression b)
at ServiceStack.OrmLite.SqlExpression`1.Visit(Expression exp)
at ServiceStack.OrmLite.SqlExpression`1.VisitLambda(LambdaExpression lambda)
at ServiceStack.OrmLite.SqlExpression`1.Visit(Expression exp)
at ServiceStack.OrmLite.SqlExpression`1.AppendToWhere(String condition, Expression predicate)
at ServiceStack.OrmLite.SqlExpression`1.Where(Expression`1 predicate)
at ServiceStack.Northwind.ServiceInterface.OrdersService.Get(Orders request) in C:\dev\ServiceStack.Examples\src\ServiceStack.Northwind\ServiceStack.Northwind.ServiceInterface\OrdersService.cs:line 19
at lambda_method(Closure, Object, Object)
at ServiceStack.Host.ServiceRunner`1.Execute(IRequest request, Object instance, TRequest requestDto)
InnerException:
解决方法:
如果我自己写一个 SQL where 子句语句,它会起作用:
if (request.ByDate.HasValue)
{ // date provided
string condition = string.Format("OrderDate = '{0}'", request.ByDate.Value.Date.ToString("yyyy-MM-dd") );
orders = Db.Select<Order>(condition);
最佳答案
ServiceStack当然可以按DateTime查询。但是在您的情况下,您试图仅按日期部分查询,而忽略时间(类似于 date(OrderDate) = date(ByDate))。事情是 - 您为此使用的表达式 (o.OrderDate.Value.Date == request.ByDate.Value.Date) 可能看起来很简单,但它实际上是由有时复杂的表达式树表示的。此表达式树由 ORM 探索并转换为原始 sql 查询。现在,表达式可以是任意复杂的,当然不是所有的表达式都可以转换为 sql 查询。 ORM 的开发者应该明确地考虑哪些表达式可能对实现有用。在这种情况下,很可能是 ORM 的开发人员在您访问 DateTime 实例的 .Date 属性时没有处理这种情况,或者由于某种原因甚至可能无法处理这种情况。您希望这会转换为类似 date(OrderDate) sql 的内容,但事实并非如此。其他 ORM(例如 Entity Framework )具有特殊函数,您可以在表达式中调用这些函数(例如:o => DbFunctions.Date(o.OrderDate)),但 ServiceStack 没有此类函数用于仅日期比较,就我知道。
长话短说 - 我会说这不是错误,只是不受支持的功能。当然,他们可能会处理并抛出更好的异常,但事实就是如此。
最后按 DateTime 查询,如您的问题所述,只需执行以下操作:
var byDate = request.ByDate.Value.Date;
orders = Db.Select<Order>(order => order.OrderDate == byDate);
关于c# - ServiceStack 可以通过 System.DateTime 值进行查询吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32638766/
我有一个带有帮助页面的 Web API 2 项目,该项目在本地运行良好,但当我将其推送到 Azure 时抛出此错误: Method not found: 'System.String System.S
我有两台服务器,但通常运行相同的设置 - IIS、SQL Server 等。一台给我这个错误,另一台没有。我从 Visual Studio 向两者发布相同的代码。 它们都在运行 .NET CLR Ve
System.out声明为 public static final PrintStream out。 但是你可以调用System.setOut()重新分配它。 嗯?如果它是 final,这怎么可能?
System.out被声明为 public static final PrintStream out。 但是您可以调用System.setOut()重新分配它。 嗯?如果是 final,这怎么可能?
我有这个 linq 查询: private void GetReceivedInvoiceTasks(User user, List tasks) { var areaIds = user.A
我有一个 MonoTouch 应用程序,当我为设备编译它时,出现以下错误: Error MT2002: Can not resolve reference: System.Boolean System
您好,我有一个名为 DailyVisitReport 的 View 。在该 View 中,我有两个名为 FromDate 和 toDate 的字段。如果我选择 FromDate 和 ToDate 取决
是否可以从 ObjectContext 对象中读取元组列表? 我在存储过程中有类似这样的数据库查询 SELECT T.Id as Item1, -- this is guid T.Wo
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我有一个方法可以从数据读取器的数据中生成类类型列表。 if (datareader != null && datareader .HasRows) { Dictionary pDict= GetP
我有一些旧的 C++ 代码,它们使用 stdio 进行输入和输出。该代码还通过 fork 生成新进程。它将 stdio 重新映射到每个新进程,以便每个 session 获取其各自的数据。 我正在考虑使
我的应用程序可以很好地构建/链接/部署到模拟器,但我只是第一次尝试将应用程序构建/部署到真实设备,并且链接器失败。 我不使用 System.Console或 ConsoleColor在我的应用程序的任
主要是我很好奇。 我们有一个名为 Unit 的对象在我们的代码库中 - 代表桥梁或道路的组件。在我们的例子中,看到带有 Unit 的 ReactiveUI 命令可能会模棱两可。作为声明中的泛型之一。
我试图将Object变量转换为StreamWriter。但是,它不起作用。有什么错? StreamWriter file = (StreamWriter) myObject; 最佳答案 myObjec
为什么以下不编译? using System; using System.Linq; using System.Linq.Expressions; public static class Extens
我正在使用 Visual Studio Community 2015 开发面向 .NET 4.5 的 Visual Basic 应用程序.我没有编写应用程序,所以我使用 NuGet 添加了所有缺失的依
我刚刚开始使用 powershell,我正在制作一个非常简单的加密功能。我想获取字符串中的每个字符,将其转换为 int 并添加一个选定的数字,然后将其转换回一个字符。 这工作正常: function
一些使用我的应用程序的人似乎变得越来越 System.MissingMethodException: Method not found: 'System.Object System.Windows.T
我是 C# 和实体的新手 我想知道是否有人在这里帮助我。我选择了哪个返回我的 customerid,所以我想将它作为参数传递给我的构造函数,我的构造函数参数类型是 guid 但我的选择类型不同,我不知
我是一名优秀的程序员,十分优秀!