美文网首页
ruby on rails,条件查询的方法:order,limi

ruby on rails,条件查询的方法:order,limi

作者: ibob2012 | 来源:发表于2019-08-22 16:31 被阅读0次

order: 对结果进行排序,eg: 将返回的对象按照名称升序排列,按照创建时间降序排列等。

limit:   对结果的数量进行限制,eg:数据库中有成千上万的注册用户,我们不希望一下子把这些用户的信息都取出来,而是希望将这些用户分页显示,点击下一页才进行下一次读取。

limit方法,是读取第一页的N个用户,第二页需要返回的用户都需要将前面的N记录跳过,这里就用到了offset方法。

所以说,order;limit;offset方法配合使用就可以实现分页功能。

User对象按照id的值进行升序排列后,跳过前面10条数据(offset),返回4条对象(limit)

User.order("id").limit(4).offset(10)

liimit , offset 方法参数都是一个整数,

limit: 限制查询记录的个数

offset:跳过记录的个数

order方法的参数接受一个sql语法的条件,格式是

table_name.column_nameASC/DSC

如果对象涉及一个表的话,可以不指定表名。不指定排序方向的话,缺省是升序。

不过我觉得最好还是别偷懒都写上吧,以增加程序的可读性和避免混乱。尤其是一个对象是由多个表join在一起以及各个表中有相同名字字段的时候。

所以上面的查询语句最好写成

User.order("user.idASC").limit(4).offset(10)

对于布尔值,false值是0,true值是1,排序的使用用得上。

相关文章

网友评论

      本文标题:ruby on rails,条件查询的方法:order,limi

      本文链接:https://www.haomeiwen.com/subject/gexosctx.html