当前位置: 首页 > 面试题库 >

PostgreSQL GROUP BY与MySQL不同吗?

胡志
2023-03-14
问题内容

我一直在将一些MySQL查询迁移到PostgreSQL以使用Heroku。我的大多数查询工作正常,但是当我使用group by时,我仍然遇到类似的重复错误:

错误:“ XYZ”列必须出现在GROUP BY子句中或在聚合函数中使用

有人可以告诉我我在做什么错吗?

可以100%运行的MySQL:

SELECT `availables`.*
FROM `availables`
INNER JOIN `rooms` ON `rooms`.id = `availables`.room_id
WHERE (rooms.hotel_id = 5056 AND availables.bookdate BETWEEN '2009-11-22' AND '2009-11-24')
GROUP BY availables.bookdate
ORDER BY availables.updated_at

PostgreSQL错误:

ActiveRecord :: StatementInvalid:PG错误:错误:列“ availables.id”必须出现在GROUP
BY子句中或在聚合函数中使用:
SELECT“ availables”。* FROM“ availables” INNER JOIN“ rooms” ON“ rooms”。 id
=“ availables” .room_id在哪里(rooms.hotel_id = 5056 AND
availables.bookdate在E‘2009-10-21’和E‘2009-10-23’之间)GROUP BY
availables.bookdate订单BY availables.updated_at

Ruby代码生成SQL:

expiration = Available.find(:all,
    :joins => [ :room ],
    :conditions => [ "rooms.hotel_id = ? AND availables.bookdate BETWEEN ? AND ?", hostel_id, date.to_s, (date+days-1).to_s ],
    :group => 'availables.bookdate',
    :order => 'availables.updated_at')

预期输出(来自有效的MySQL查询):

+ ----- + ------- + ------- + ------------ + --------- + ---- ----------- + --------------- +
| id | 价格| 点| 预定日期 room_id | created_at | Updated_at |
+ ----- + ------- + ------- + ------------ + --------- + ---- ----------- + --------------- +
| 414 | 38.0 | 1 | 2009-11-22 | 1762年| 2009-11-20 ... | 2009-11-20 ... |
| 415 | 38.0 | 1 | 2009-11-23 | 1762年| 2009-11-20 ... | 2009-11-20 ... |
| 416 | 38.0 | 2 | 2009-11-24 | 1762年| 2009-11-20 ... | 2009-11-20 ... |
+ ----- + ------- + ------- + ------------ + --------- + ---- ----------- + --------------- +
套装3行

问题答案:

GROUP BYPostgres可以模拟完全不符合MySQL标准的MySQL DISTINCT ON。考虑一下:

MySQL:

SELECT a,b,c,d,e FROM table GROUP BY a

每个值传送1行a(您实际上并不知道该行)。好的,实际上您可以猜测,因为MySQL不了解哈希聚合,因此它可能会使用sort
…,但只会排序a,因此行的顺序可以是随机的。除非它使用多列索引而不是排序。好吧,无论如何,它不是由查询指定的。

Postgres:

SELECT DISTINCT ON (a) a,b,c,d,e FROM table ORDER BY a,b,c

这样,每个值传送1行a,该行将是根据ORDER BY查询指定的排序中的第一行。简单。

请注意,这里不是我正在计算的汇总。所以GROUP BY实际上没有任何意义。DISTINCT ON更有意义。

Rails已与MySQL结为夫妻,因此对于它生成的SQL在Postgres中不起作用,我并不感到惊讶。



 类似资料:
  • 问题内容: 在另一个问题中,我发布了一个人告诉我,两者之间是有区别的: 和: 在MySQL中。他还提到了MSSQL如何具有批处理范围,而MySQL如何具有会话范围。有人可以为我详细说明吗? 问题答案: 具有 用户定义变量 的概念。 它们是松散类型的变量,可以在会话的某处初始化,并保持其值直到会话结束。 它们前面带有一个标志,如下所示: 您可以使用语句或在查询内部初始化此变量: 在中开发存储过程时,

  • 问题内容: 我正在尝试选择mysql表中的重复行,它对我来说很好,但问题是它不是让我选择该查询中的所有字段,而是让我选择用作不同的字段名,让我写查询更好的了解 第一个工作正常 现在,当我尝试选择所有字段时,我最终会出现错误 我正在尝试选择最新的重复项,比如说ticket_id 127是行ID 7、8、9的3倍,因此我想选择一次,最新条目在这种情况下为9,这适用于所有其余项ticket_id的 任何

  • 问题内容: 我最近将Debian 5.0.4服务器上的MySQL升级到了5.1。现在,phpMyAdmin显示以下警告: 可能会引起任何问题吗? 问题答案: 该消息表明: 您正在使用 MySQL服务器的5.1.43版本 但是, PHP 用于与该服务器通信的 库 已被编译为与MySQL 5.0.x版本 通信。 从理论上讲, 这不会引起任何实际的问题 :次要版本倾向于兼容;但是您可能需要更新PHP使用

  • 我试图建立MySQL查询与多个连接,其中加入的值的总和。有3个表:保管人,帐户和存款。账户和存款通过客户的customer_id字段连接到客户。在查询结束时,所有客户都按group_id分组: 问题是:连接的行重复,而我必须进行一些分析:汇总所有存款金额-您可以在这里看到我针对存款金额的解决方法。但真正的问题是如何计算“客户的首次存款”。在对结果进行分组之前,我们可能会看到: 所以,我需要的是总和

  • 我会跟踪哪些人登录到我们的本地服务器,如下面的数据库所示。 我的数据库结构是:

  • 有没有人知道Java10和JVM10规范的版本与以前的版本不同?对于Java8和Java9,有不同的规范,很难看到有什么变化。