首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Server中跨三个表按组

在Server中跨三个表按组
EN

Stack Overflow用户
提问于 2012-08-11 11:10:16
回答 1查看 895关注 0票数 1

我发现我不知道如何在Server中对查询结果进行分组。Server 2005有三个表:

域:

代码语言:javascript
复制
- id
- name

实体:

代码语言:javascript
复制
- domain_id
- user_id

用户:

代码语言:javascript
复制
- id
- login

因此,这是跨第三个表的两个表之间的公共关系,其中多个域可能与一个用户相关。

T查询:

代码语言:javascript
复制
SELECT domain.name, users.login 
FROM domain, entity, users 
WHERE domain.id = entity.domain_id AND entity.user_id = users.id 
GROUP BY users.login, domain.name

返回:

代码语言:javascript
复制
+------+-------+
| name | login |
+------+-------+
| dom1 | user1 |
| dom4 | user1 |
| dom5 | user1 |
| dom2 | user2 |
| dom3 | user3 |
+------+-------+

我的问题是如何创建返回与MySQL相同的MySQL查询:

代码语言:javascript
复制
SELECT domain.name, user.login 
FROM domain, entity, user 
WHERE domain.id = entity.domain_id AND entity.user_id = user.id 
GROUP BY user.login

+------+-------+
| name | login |
+------+-------+
| dom5 | user1 |
| dom2 | user2 |
| dom3 | user3 |
+------+-------+
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-08-11 11:34:16

创建返回与MySQL相同的MySQL(以及大多数标准实现)

代码语言:javascript
复制
SELECT MAX(domain.name), user.login  
FROM domain, entity, user  
WHERE domain.id = entity.domain_id AND entity.user_id = user.id  
GROUP BY user.login 

在这两种环境中,FROM / WHERE联接将更好地表示为

代码语言:javascript
复制
FROM domain
    INNER JOIN entity
         ON domain.id = entity.domain_id 
    INNER JOIN user  
         ON entity.user_id = user.id  
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11914174

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档