0

我需要使用 Paris/idiorm PHP 来构建我的查询。我尝试了很多可能性,但找不到解决方案。我是 PHP 和 SQL 的新手,对 ORM 了解不多。我只是认为有人会帮助我构建查询以获取上次更新时间戳的不同名称。

-----------------------------------------
id  |   name       |    timestamp
-----------------------------------------
1   |   testuser   |  2012-11-19 17:02:48
2   |   testuser   |  2012-11-28 11:15:46
3   |   testuser   |  2012-11-19 11:02:49
4   |   testadmin  |  2012-11-28 10:50:05
5   |   testadmin  |  2012-11-28 11:15:46
-----------------------------------------

我进行了以下查询,并且能够获取名称及其第一个时间戳,但无法获取最新的时间戳

    $output = ORM::for_table('sample')
                ->raw_query('SELECT id,name,timestamp FROM sample GROUP BY name',array())
                ->find_many();

希望有一些解决方案。

4

3 回答 3

1

获取子查询中每个名称的最新时间戳,然后将其加入自身。尝试,

SELECT a.*
FROM    tableName a
        INNER JOIN
        (
            SELECT name, MAX(timestamp) maxStamp
            FROM tableName
            GROUP BY name
        ) b ON a.name = b.name AND
                a.timestamp = b.maxStamp
于 2012-11-28T08:24:15.347 回答
0
 $output = ORM::for_table('sample')
                ->raw_query('SELECT DISTINCT(name),id,timestamp FROM sample ORDER BY id DESC',array())
                ->find_many();

希望这可以帮助

我尝试向您订购 DESC,您将获得用户的最后或最新日志

于 2012-11-28T08:29:13.067 回答
0
$output = ORM::for_table('sample')
  ->distinct()
  ->raw_query('SELECT id,name,timestamp FROM sample GROUP BY name',array())
  ->find_many();
于 2012-11-28T08:25:34.227 回答