首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL查询-连接子查询

MySQL查询-连接子查询
EN

Stack Overflow用户
提问于 2015-09-28 06:57:15
回答 1查看 62关注 0票数 0

我有什么

我有这么多张桌子:

  • tbl_hw_inventar (hw_id,主机名,hw_typ_idfs,hw_created_user_idfs等)
  • tbl_hw_typ (hw_typ_id,hw_typ_title等.)
  • tbl_user (user_id,用户名等)
  • tbl_hw_edited (hw_edited_id、hw_edited_client_idfs、hw_edited_date、hw_edited_user_idfs)

我需要什么

我希望输出一个包含以下信息的表:

代码语言:javascript
复制
 hw_id | Hostname | created                         | last edited 

 12315 | client-01 | 2015-05-06 15:31:06 (username) | 2015-07-02 09:46:17 (username) |

问题

正如您所看到的,我可以获得像hw_typ这样的信息,包括一个外键和一个内部连接到"tbl_hw_typ“。对于带有"hw_created_user_idfs“和内部连接的信息也是如此,以获得用户to 用户名

但是如何获得上一次编辑的datetime用户名

在我的表"tbl_hw_edited“中,有这样的条目:

代码语言:javascript
复制
row id | hw_id | datetime | user_id

代码

到目前为止,我的SQL查询如下:

代码语言:javascript
复制
SELECT `tbl_hw_inventar`.*, `tbl_hw_typ`.`hw_typ_title`, `tbl_user`.`username`, `tbl_hw_edited`.`hw_edited_id` 
FROM `tbl_hw_inventar` 
INNER JOIN `tbl_hw_typ` 
ON `tbl_hw_inventar`.`hw_typ_idfs` = `tbl_hw_typ`.`hw_typ_id` 
INNER JOIN `tbl_user` 
on `tbl_hw_inventar`.`hw_create_user_idfs` = `tbl_user`.`id`
JOIN (
    SELECT MAX(`tbl_hw_edited`.`hw_edited_id`), `tbl_hw_edited`.`hw_edited_client_idfs`
    FROM `tbl_hw_edited`
    ) `tbl_hw_edited` ON `tbl_hw_inventar`.`hw_id` = `tbl_hw_edited`.`hw_edited_client_idfs`
ORDER BY `tbl_hw_inventar`.`hw_id` ASC

那么我怎样才能输出信息呢?看起来我必须在我的查询中做一个子查询。但每次尝试都失败了。

谢谢你帮助

编辑

按照建议,我将为每个表提供更多信息(表数据):

代码语言:javascript
复制
-tbl_hw_inventar-
| hw_id | hw_hostname | hw_create_date      | hw_create_user_idfs |
| 1     | client-01   | 2015-03-06 11:57:42 | 1                   |
| 2     | client-02   | 2015-09-21 21:17:00 | 3                   |

-tbl_hw_edited-
| hw_edited_id | hw_edited_client_idfs | hw_edited_date      | hw_edited_user_idfs |
| 1            | 1                     | 2015-09-24 17:30:22 | 1                   |
| 2            | 2                     | 2015-09-24 16:33:22 | 2                   |
| 3            | 1                     | 2015-09-24 23:30:22 | 2                   |
| 4            | 2                     | 2015-09-24 20:30:22 | 3                   |

-tbl_user-
| id | username |
| 1  | ismaelw  |
| 2  | skalb    |
| 3  | yrumpel  |

因此,作为最终结果,我需要这样的输出:

代码语言:javascript
复制
| hw_id | hostname  | created                       | edited                      |
| 1     | client-01 | 2015-03-06 11:57:42 (ismaelw) | 2015-09-24 23:30:22 (skalb) |
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-09-28 07:19:51

如果我正确地解释了您的表,您需要为每个hw_edited_client_idfs (它加入到hw_id)找到最大值(编辑日期)。

代码语言:javascript
复制
                            SELECT
                                  hw_edited_client_idfs
                                , MAX(hw_edited_date) AS last_edit_dt
                            FROM tbl_hw_edited
                            GROUP BY hw_edited_client_idfs

有了这个结果,您可以将其加入到源表中,以发现哪个用户与max(编辑日期)相关联。

代码语言:javascript
复制
                SELECT
                      het.*
                FROM tbl_hw_edited AS het
                      INNER JOIN (
                            SELECT
                                  hw_edited_client_idfs
                                , MAX(hw_edited_date) AS last_edit_dt
                            FROM tbl_hw_edited
                            GROUP BY hw_edited_client_idfs
                      ) AS mx ON het.hw_edited_client_idfs = mx.hw_edited_client_idfs
                                  AND het.hw_edited_date = mx.last_edit_dt

然后这个结果如下所用:

代码语言:javascript
复制
SELECT
      i.hw_id
    , i.hw_hostname
    , uc.username created_by
    , he.hw_edited_date last_edit_date
    , ue.username last_edit_by
FROM tbl_hw_inventar AS i
      INNER JOIN tbl_user AS uc ON i.hw_create_user_idfs = uc.id
      LEFT OUTER JOIN (
                SELECT
                      het.*
                FROM tbl_hw_edited AS het
                      INNER JOIN (
                            SELECT
                                  hw_edited_client_idfs
                                , MAX(hw_edited_date) AS last_edit_dt
                            FROM tbl_hw_edited
                            GROUP BY hw_edited_client_idfs
                      ) AS mx ON het.hw_edited_client_idfs = mx.hw_edited_client_idfs
                                  AND het.hw_edited_date = mx.last_edit_dt
          ) AS he ON i.hw_id = he.hw_edited_client_idfs
      LEFT OUTER JOIN tbl_user AS ue ON he.hw_edited_user_idfs = ue.id

它产生了这样的结果:

代码语言:javascript
复制
| hw_id | hw_hostname | username |              hw_edited_date | username |
|-------|-------------|----------|-----------------------------|----------|
|     1 |   client-01 |  ismaelw | September, 24 2015 23:30:22 |    skalb |
|     2 |   client-02 |  yrumpel | September, 24 2015 20:30:22 |  yrumpel |

请参阅这只小提琴

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32817269

复制
相关文章

相似问题

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