使用 Doctrine 按多列排序

Order by multiple columns with Doctrine(使用 Doctrine 按多列排序)
本文介绍了使用 Doctrine 按多列排序的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要按两列对数据进行排序(当行的第 1 列有不同的值时,按它排序;否则,按第 2 列排序)

I need to order data by two columns (when the rows have different values for column number 1, order by it; otherwise, order by column number 2)

我正在使用 QueryBuilder 来创建查询.

I'm using a QueryBuilder to create the query.

如果我再次调用 orderBy 方法,它会替换任何之前指定的排序.

If I call the orderBy method a second time, it replaces any previously specified orderings.

我可以传递两列作为第一个参数:

I can pass two columns as the first parameter:

->orderBy('r.firstColumn, r.secondColumn', 'DESC');

但是我不能为第二个参数传递两个排序方向,所以当我执行这个查询时,第一列按升序排序,第二列按降序排序.我想对它们都使用降序.

But I cannot pass two ordering directions for the second parameter, so when I execute this query the first column is ordered in an ascending direction and the second one, descending. I would like to use descending for both of them.

有没有办法使用 QueryBuilder 做到这一点?我需要使用 DQL 吗?

Is there a way to do this using QueryBuilder? Do I need to use DQL?

推荐答案

你要在列名后面加上下单方向:

You have to add the order direction right after the column name:

$qb->orderBy('column1 ASC, column2 DESC');

如您所述,多次调用 orderBy 不堆叠,但您可以多次调用 addOrderBy:

As you have noted, multiple calls to orderBy do not stack, but you can make multiple calls to addOrderBy:

$qb->addOrderBy('column1', 'ASC')
   ->addOrderBy('column2', 'DESC');

这篇关于使用 Doctrine 按多列排序的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Convert JSON integers and floats to strings(将JSON整数和浮点数转换为字符串)
in php how do I use preg replace to turn a url into a tinyurl(在php中,如何使用preg替换将URL转换为TinyURL)
all day appointment for ics calendar file wont work(ICS日历文件的全天约会不起作用)
trim function is giving unexpected values php(Trim函数提供了意外的值php)
Basic PDO connection to MySQL(到MySQL的基本PDO连接)
PHP number_format returns 1.00(Php number_Format返回1.00)