Ruby on rails开发从头来(四十七)- ActiveRecord基础(强大的find方法) - 编程入门网
作者 佚名技术
来源 NET编程
浏览
发布时间 2012-06-14
del对象中都包含有哪些属性呢?我们使用attributes( ), attribute_names( ), and attribute_present?( )方法来确定在Model对象中都包含有哪些属性,第一个返回一个hash,里面是键值对,第二个返回属性名的数组,第三个判断Model对象中是否含有某个属性,例如:
orders = Order.find_by_sql("select name, pay_type from orders") first = orders[0] p first.attributes p first.attribute_names p first.attribute_present?("address") 程序的结果: {"name"=>"Dave Thomas", "pay_type"=>"check"} ["name", "pay_type"] false find_by_sql方法也可以用来创建包含有派生(derived)(注1)的Model对象,如果你使用了as XXX 这样的sql来给派生字段一个别名,这个别名会作为Model中的属性名,例如: items = LineItem.find_by_sql("select *, " + " quantity*unit_price as total_price, " + " products.title as title " + " from line_items, products " + " where line_items.product_id = products.id ") li = items[0] puts "#{li.title}: #{li.quantity}x#{li.unit_price} => #{li.total_price}" 在find_by_sql方法中,我们一样可以使用占位符来给Sql语句传递参数,例如: Order.find_by_sql(["select * from orders where amount > ?", params[:amount]]) |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
上一篇: Ruby on rails开发从头来(五十八)- ActiveRecord基础(自关联) - 编程入门网下一篇: Ruby on rails开发从头来(四十)- ActiveRecord基础(Boolean属性) - 编程入门网
关于Ruby on rails开发从头来(四十七)- ActiveRecord基础(强大的find方法) - 编程入门网的所有评论