我正在为数据库使用 Laravel 5.6 和 MySQL
public function getTopPaid(){
$books = Book::with('users')->where('price', '>', 0 )->get()
->sortByDesc(function ($book){
return $book->users->count();//sorting by purchased users count
})->take(25);
return new BooksWithAuthors($books);
}
我想用上面的代码获得购买次数最多的付费图书。这很好,响应时间为 1700 毫秒。以及大约 400 条记录。
但是下面的代码几乎是一样的:
public function getTopFree(){
$books = Book::with('users')->where('price', '=', 0 )->get()
->sortByDesc(function ($book){
return $book->users->count();
})->take(25);
return new BooksWithAuthors($books);
}
结果只有34条记录,但RESPONSE在8000毫秒内。代码中唯一的区别是 “等于”
where('price', '>', 0 )
和
where('price', '=', 0 )
为什么第二个查询这么慢?以及如何解决这个问题
最佳答案
MySQL 默认将其索引存储在 BTREE 中。一般没有散列。
对于性能差异的简短回答是 > 形式比 = 形式计算更多的节点。
关于php - 等于零的地方太慢了,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52163065/
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我来自C、php和bash背景,很容易学习,因为它们都有相同的C结构,我可以将其与我已经知道的联系起来。然后2年前我学了Python并且学得很好,Python对我来说比Ruby更容易学。然后从去年开始,我一直在尝试学习Ruby,然后是Rails,我承认,直到现在我还是学不会,讽刺的是那些打着简单易学的烙印,但是对于我这样一个老练的程序员来说,我只是无法将它
我有一个表单,我的用户可以在其中注册到我的网站。他们在表格中填写自己的生日:生日、生日和生日。所以我使用Range以这样的形式创建选择:=f.select(:birthmonth,options_for_select((1..12)))但这并没有像我想要的那样以零开头的单个数字:01、02、03、04、05、06、07、08、09、10等等。我什至试过了,但没用:=f.select(:birthmonth,options_for_select((01..12)))有人知道如何让Range以前导零开头吗?或者任何其他方式来做到这一点,以便我可以在验证中使用它?:validates_inc
运行:require'date'y=Date.newputs"defaultyearis#{y.year}"输出:defaultyearis-4712Date对象的年份默认为-4712是否有任何特殊原因?我认为也许有技术(或传统)原因。我用谷歌搜索并在Ruby文档(2.2.3)中查找了它,但我找不到关于为什么的答案。 最佳答案 公元前4713年1月1日是Julianday的开始,来自维基:TheJulianDayNumber(JDN)istheintegerassignedtoawholesolardayintheJulianday
我越来越熟悉ruby发送方法,但出于某种原因,我不能做这样的事情a=4a.send(:+=,1)出于某种原因,这不起作用。然后我尝试了类似a.send(:=,a.send(:+,1))但这也行不通。通过“发送”触发加等于的正确方法是什么? 最佳答案 我认为基本选项只有:a=a.send(:+,1)那是因为send是将消息发送给对象。赋值修改的是一个变量,而不是一个对象。可以通过一些元编程直接赋值给变量,但是代码很复杂,到目前为止我能找到的最好的是:a=1var_name=:aeval"#{var_name}=#{var_name
在Ruby中,我想在另一个对象中捕获在一个对象上生成的NoMethodError,然后将一些值返回到引发异常的位置并继续执行。有没有现成的方法可以做到这一点?我想到的最好的是:classExceptionattr_accessor:continuationendclassOuterdefhelloputs"hello"endclassInnerdefworldputs"world"enddefmethod_missing(method,*args,&block)x=callccdo|cc|e=RuntimeError.exception(method)e.continuation=cc
有没有一种简单的方法可以在查询中调用类似于数据库的东西?“mystring”是否存在于["string1","mystring","string2"]=>会返回true“mystring”是否存在于["string1","string2","string3"]=>会返回false 最佳答案 ["string1","mystring","string2"].include?"mystring"参见:Enumerable#include? 关于Ruby字符串是否等于字符串数组中的一个字符串?
我数据库中的日期如下所示:2012-07-23我正在尝试查看日期是否早于7天前且少于14天前,或者查看日期是否大于14天前,但我没有运气..这是我的代码:defprogress_report_status_check(date)progress_date=date.to_dateseven_days=7.days.ago.to_datefourteen_days=14.days.ago.to_dateifseven_days>(progress_date-7.days.ago.to_date)or(progress_date-14.days.ago.to_date)fourteen_d
我想构建一个州缩写列表数组,由于它很长,我想将它分成几行。但是,使用%w或%W包括换行处的\n。STATES=%w(ALAKAZARCACOCTDEFLGAHIIDILINIAKSKYLAME\MDMAMIMNMSMOMTNENVNHNJNMNYNCNDOHOKORPARISCSD\TNTXUTVTVAWAWVWIWY)因此"ME"将是"ME\n","SD"将是"SD\n"我该如何解决这个问题? 最佳答案 只去掉斜杠,不会有任何换行符或斜杠 关于ruby-如何在Ruby中%w[text]
条件:a+b+c=100a,b,cpositiveintegersor0期望的输出:[[0,0,100],[0,1,99],...#allotherpermutations[99,1,0],[100,0,0]] 最佳答案 我会写:(0..100).flat_map{|x|(0..100-x).map{|y|[x,y,100-x-y]}}#=>[[0,0,100],[0,1,99]],...,[99,1,0],[100,0,0]]站点注释1:这是一个经典示例,其中列表推导式大放异彩(如果某处有条件则更是如此)。由于Ruby没有LC,我
我得到错误作为undefinedvariable,我知道nil如果用作bool值则被评估为false:ifyputs"Something"end 最佳答案 undefinedvariable不等于nil。未定义的instance变量返回nil(同样,如果它未定义)。y引发异常@y返回nil 关于ruby-Ruby中undefinedvariable等于nil吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow