• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL转PostgreSQL 的Group by有关问题 100分

mysql 搞代码 7年前 (2018-05-31) 173次浏览 已收录 0个评论

mysql转PostgreSQL 的Group by问题 100分
呵呵又是MySQL转PostgreSQL的问题
这次是Group by得问题了
MySQL的Group by 后面分组的列不一定要和查询的列一致 
但是PostgreSQL的Group by是必须一致的
这是原来

SQL code

 SELECT u.UserCD ,SUBSTRING(OperationDT,9,2) AS DateDay FROM mytable GROUP BY SUBSTRING(OperationDT,1,10) 

欢迎大家阅读《MySQL转PostgreSQL 的Group by有关问题 100分》,跪求各位点评,by 搞代码

这句的意思是我想分组SUBSTRING之后的值 MySQL中不会出错的

可是在PostgreSQL中 由于我查询中要查SUBSTRING(OperationDT,9,2) AS DateDay
所以GROUP BY中必须要写OperationDT 这样就不是我想要的结果了
顺便说下OperationDT是时间 YYYY-MM-DD hh:mmss格式的

最好有简单的方法 SQL文别改太长

——解决方案——————–
这句的意思是我想分组SUBSTRING之后的值 MySQL中不会出错的
不是标准的 SQL语句

SELECT u.UserCD ,to_char(OperationDT, 'YYYY-MM-DD ') AS DateDay
FROM mytable
GROUP BY u.UserCD ,to_char(OperationDT, 'YYYY-MM-DD ')
——解决方案——————–
SELECT u.UserCD ,SUBSTRING(OperationDT,9,2) AS DateDay
FROM mytable
GROUP BY u.UserCD,SUBSTRING(OperationDT,1,10)

加上 u.UserCD,

或者

SELECT min(u.UserCD) ,SUBSTRING(OperationDT,9,2) AS DateDay
FROM mytable
GROUP BY SUBSTRING(OperationDT,1,10)


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL转PostgreSQL 的Group by有关问题 100分

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址