- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Xamarin 构建汽车管理应用程序,我的后端是 ASP.NET Web API。我有一个大型汽车数据集,可以按品牌、名称、年份、里程表和发动机容量找到汽车的价格。我尝试对大部分值进行平均,以便可以找到数据,但很多时候它不会返回任何内容。因此,我决定尝试多次查询数据库,但每次它不返回任何内容,我要么将一个值转换为一个区间(例如,里程表 = 100000,然后里程表 >= 80000 && 里程表 <= 120000)。它有点像这样,但我认为这不是正确的编写方式。我正在考虑策略模式,但不知道如何应用于我的案例。
我尝试过的是在存储库中获取汽车对象,然后我有六个方法只查询数据库,每个方法逐渐使用更少的参数。有很多 If Else。
public GetCarPriceResponse GetPrice(GetCarPriceRequest car)
{
var price = new GetCarPriceResponse
{
Errors = new List<string>()
};
if (GetPriceFirst(car) == null)
if (GetPriceSecond(car) == null)
if (GetPriceThird(car) == null)
if (GetPriceFourth(car) == null)
if (GetPriceFifth(car) == null)
if (GetPriceSixth(car) == null)
{
price.Success = false;
price.Errors.Add("Could not find car
price");
}
else
{
price = GetPriceSixth(car);
}
else price = GetPriceFifth(car);
else price = GetPriceFourth(car);
else price = GetPriceThird(car);
else price = GetPriceSecond(car);
else price = GetPriceFirst(car);
price.Success = true;
return price;
}
第一个函数如下所示:
public GetCarPriceResponse GetPriceFirst(GetCarPriceRequest car)
{
var prices = _context.CarPrices.Where(p =>
p.make == car.make &&
p.model == car.model &&
p.year == car.year &&
p.CC == car.CC &&
p.odometer == car.odometer).ToList();
if (prices.Count == 0) return null;
return CalculateAveragePrice(prices);
}
第三个是这样的:
public GetCarPriceResponse GetPriceThird(GetCarPriceRequest car)
{
var differenceDown = 0;
var differenceUp = 0;
if (car.odometer < 50000)
{
differenceDown = 0;
differenceUp = 50000;
}
else if (car.odometer > 50000)
{
differenceDown = 50000;
differenceUp = 50000;
}
else if (car.odometer > 215000)
{
differenceDown = 50000;
differenceUp = 0;
}
var prices = _context.CarPrices.Where(p =>
p.make == car.make &&
p.model == car.model &&
p.year == car.year &&
p.CC == car.CC &&
p.odometer >= car.odometer - differenceDown &&
p.odometer <= car.odometer + differenceUp).ToList();
if (prices.Count == 0) return null;
return CalculateAveragePrice(prices);
}
在第四个中,我完全消除了里程表参数,在第六个中,我查询了另一个数据库,该数据库具有基于里程表、发动机容量和型号年份的平均价格。这是第五种方法:
public GetCarPriceResponse GetPriceFifth(GetCarPriceRequest car)
{
var prices = _context.CarPrices.Where(p =>
p.make == car.make &&
p.model == car.model &&
p.year >= car.year - 2 &&
p.year <= car.year + 2 &&
p.CC == car.CC).ToList();
if (prices.Count == 0) return null;
return CalculateAveragePrice(prices);
}
目前工作正常,但例如如果添加一辆电动汽车,发动机容量为0,则无法正常工作等等。但我想问是否有办法让这段代码变得更好。
谢谢。
最佳答案
不要每次都尝试查找一辆汽车,而是让查询返回与制造
、型号
、年份
和CC
(因为这似乎是通用标准)并按里程表值对结果进行排序。然后,您的应用可以浏览列表(使用本地 LINQ 查询)以查找列表中的最佳匹配项。
由于所有网络流量,尝试多次查询单个匹配项将会变得太慢。
关于c# - 如果第一次没有找到任何内容,如何正确地多次查询数据库以获取某个值 C#,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56393098/
我在 Web 应用程序中尝试了一些字节码操作,到目前为止,效果很好。现在我需要在代码中的某些特定位置注入(inject)一些字节代码。我用 switch 语句和 method.inserAt(); 尝
我正在尝试对数组中的对象值求和,然后计算每个值相对于总数的百分比。 这里是数组: [ { "ratiototale": [ [ { "0":
我在接口(interface)中有以下方法.. Task> SearchAsync(TU searchOptions); 效果很好。 现在我正在尝试进行单元测试以测试何时出现问题 - 代码会抛出异常。
我似乎无法让 reveal 开始工作,我已经严格遵守所有内容,添加 modernizr,添加插件,添加 css(reveal 显然包含在 foundation 中),在开始时初始化 foundatio
我正在尝试移植 raspberrypi's userspace 的位从 C 到 golang 的代码,我遇到了一个涉及 ioctl() 的程序。 我在执行 C 代码时遇到了问题 #define MAJ
我一直在尝试用纯 Java 制作一个简单的游戏,但在绘图时遇到了问题。我正在尝试保持相对较高的帧速率,但是 JFrame.repaint() 不能被“强制”并且只是在下一个可用机会重绘帧的请求这一事实
给定一个字符串 "2*(i+j) = 20 我想返回 ((lambda x: x >= 20), ['i']) 我可以然后直接提供给 constraint。 最佳答案 您正在寻找 eval 的替代方法
我对改进我的 javascript 代码以使其成为正确的 OOP 很感兴趣....目前我倾向于做这样的事情: jQuery(document).ready(function () { Page
我有一个调用两个动画 Action 的事件监听器。不幸的是,它们的开始有少量错开(例如,函数中的第一个首先开始)。 有谁知道正确同步它们的方法吗? 这是我的代码: $("#nav ul li a").
我只需要检查目录是否存在!但是,如果目录是“E:\Test”,其中 E: 是 CD/DVD 驱动器,并且上面没有插入磁盘,我会看到以下 Delphi 和 Windows 问题。 第一种方法: func
同样的问题: https://stackoverflow.com/questions/11294207/exchange-web-services-argumentexception-using-my
如果您跳转到 this question 中的第一个答案你会看到他使用 Employee.prototype = new Person(); 将 Person.prototype 继承到 Employ
我需要知道如何正确地遍历元素的 ArrayList 并计算元素在列表中出现的次数,而无需事先知道该元素。我尝试了几种方法并且有一种目前有效,但我觉得它很丑陋且不合适。 为了更深入地解释,我有一个 ja
我有一个用 Python 编写的(非常基本但工作完美的)AWS lambda 函数,但是它具有嵌入式凭证以连接到:1)外部网络服务2) DynamoDB 表。 该函数的作用相当基本:它针对服务发布登录
我很好奇 Tornado 推荐的查询 Redis(或任何数据库)的方法是什么。 我见过一些像 https://gist.github.com/357306 这样的例子但他们似乎都在使用对 redis
这更像是一个“我做得对吗”的问题。 快速背景故事:我已经构建了一个 gradle 插件(在一个独立的 gradle/groovy 项目中)。我在另一个 java 项目中使用它。客户项目通过以下方式引用
在我的代码中,我有: function handleMessage() { const twilio = require('twilio')(process.env.TWILIO_ACCOUNT_
我正在努力在 Linux 中刷新嵌入式设备的先前 ROM 转储。我以前的转储包含 oob 数据。我是用nandwrite -n -N -o/dev/mtd0 backup.bin写的,然后再做一次RO
我正在尝试使用 go 为 react-router 提供服务,我已经做到了,但我遇到了麻烦,我认为我做的方式不正确,或者不完整。我正在使用 Mux。我遇到的麻烦是当我按下 时在我的应用程序中,它正确
我正在尝试 promise JSON.parse 方法,但不幸的是没有任何运气。这是我的尝试: Promise.promisify(JSON.parse, JSON)(data).then((resu
我是一名优秀的程序员,十分优秀!