1

在我的数据库中,我有两个名为start_dateand的列,如果今天的日期在andend_date之间,我想从我的数据库中获取条目。我当前的查询代码如下,但它没有返回我所期望的:start_dateend_date

def updateMess
  @mess = MessType.find(params[:id_param])
  @today = Date.today
  @mess_current_price = MessPrice.where('mess_id = ? AND DATE(?) BETWEEN start_date AND end_date', @mess.mess_id, @today)

  respond_to do |format|
    format.json { render :json => { :_mess => @mess, :_mess_price => @mess_current_price } }
  end
end

上面的where命令生成以下查询(如控制台所示):

MessPrice Load (0.4ms) SELECT mess_prices.* FROM mess_pricesWHERE (DATE('2013-07-01') BETWEEN start_date AND end_date)

在 17 毫秒内完成 200 次 OK(查看次数:3.1 毫秒 | ActiveRecord:2.7 毫秒)

编辑:以下是我的 javascript 代码,我使用解析的 JSON 数据在我的视图中设置字段,但它没有在我的视图中设置字段:

$(document).on('click', ".mess-update-reveal", function(){
  $.post('/mess/updateMess',{id_param :$(this).attr('data-mess-id')}, function(data){
    var mess = data._mess;
    var messPrice = data._mess_price;
    console.log(data);
    $('#id_param_update_mess').val(mess.mess_id);
    $('#mess_name_update').val(mess.mess_name);
    $('#id_mess_charge_update').val(messPrice.id);
    $('#mess_breakfast_charge_update').val(messPrice.breakfast_charge);
    $('#mess_lunch_charge_update').val(messPrice.lunch_charge);
    $('#mess_dinner_charge_update').val(messPrice.dinner_charge);
    $('#mess_monthly_charge_update').val(messPrice.monthly_charge);
    $('#mess_semesterly_charge_update').val(messPrice.semesterly_charge);
    $('#mess_capacity_update').val(mess.mess_capacity);
    $('#start_date_update').val(messPrice.start_date);
    $('#end_date_update').val(messPrice.end_date);
    $('#rebate_update').val(messPrice.rebate);
  });
});

显示的结果console.log(data)如下:

Object
_mess: Object
created_at: "2013-06-26T07:16:58Z"
hostel_id: null
mess_capacity: 200
mess_id: 1
mess_name: "Mess1"
updated_at: "2013-06-29T12:08:08Z"
__proto__: Object
_mess_price: Array[1]
0: Object
breakfast_charge: 30
created_at: null
dinner_charge: 45
end_date: "2013-12-31"
id: 1
lunch_charge: 45
mess_id: 1
monthly_charge: 2000
rebate: 100
semesterly_charge: 11000
start_date: "2013-06-01"
updated_at: "2013-06-29T12:38:51Z"
__proto__: Object
length: 1
__proto__: Array[0]
__proto__: Object
4

4 回答 4

5

data._mess_price是一个数组,因此您要么必须返回数组中的第一个元素:

var messPrice = data._mess_price[0];

或通过在 ActiveRecord 调用结束时使用来确保它data._mess_price不是数组:first

@mess_current_price = MessPrice.where('mess_id = ? AND DATE(?) BETWEEN start_date AND end_date', @mess.mess_id, @today).first

你使用的方式没有问题BETWEEN。查询工作正常。

于 2013-07-02T04:08:56.770 回答
0

参考这个这个

MessPrice.where('start_date < ? AND end_date > ?', @today,  @today)

between 子句的语法类似于以下

SELECT column_name(s)
FROM table_name
WHERE column_name BETWEEN value1 AND value2;

您在哪里使用它,如下所示

SELECT column_name(s)
FROM table_name
WHERE value BETWEEN column_name1 AND column_name2;

可能这就是它没有按预期工作的原因

于 2013-07-01T07:00:02.273 回答
0

您可以使用下面的 gem 来查找日期之间的记录,

这个 gem 很容易使用和更清晰Star正在使用这个 gem,API 更清晰,文档也得到了很好的解释。

MessPrice.today #take all the 2 days records

在这里你也可以通过我们的领域MessPrice.by_month("January", field: :updated_at)

请查看文档并尝试一下。

于 2015-02-05T13:07:06.723 回答
-2

基本上,如果该记录在开始日期和结束日期之间可用于(例如)销售,则您想列出记录的混乱价格率。

我为此使用了 find_by_sql,您可以进一步改进它:

MessPrice.find_by_sql("SELECT * FROM mess_prices WHERE '#{Date.today}' BETWEEN start_date AND end_date")
于 2013-07-01T07:17:29.490 回答