Mysql查询到平均时间

Jac*_*ard 5 php mysql sql time average

我玩了很多棋盘游戏,并且我维护着一个跟踪几个统计数据的站点/数据库.其中一个表记录了不同的时间.它的结构如下:

  • gameName(文本 - 棋盘游戏的名称)
  • numPeople(int - 播放的人数)
  • timeArrived(时间戳 - 我们到达我们正在玩游戏的房子的时间)
  • beginSetup(时间戳 - 我们开始设置游戏的时间)
  • startPlay(时间戳 - 我们实际开始玩游戏的时间)
  • gameEnd(时间戳 - 游戏结束的时间)

基本上,我想要做的是利用这些时间来获取一些有趣/有用的信息(比如平均花费最长的游戏设置,平均花费的游戏时间最长,游戏最长的是什么到达完成等等...)通常情况下,我过分依赖PHP而且我只会做一个select*...并且一直抓住然后做一些PHP计算来查找所有的统计数据但我知道MySQL可以通过查询为我做所有这些.不幸的是,当谈到更复杂的查询时,我很失落,所以我想要一些帮助.

我想要几个查询的一些例子,希望一旦有人让我开始,我可以找出其他平均时间查询.对于玩棋盘游戏,平均查询时间最长的是什么?平均设置最快的游戏/时间怎么样?

附加信息: drew010 - 你让我有一个良好的开端,但我没有得到我期望的结果.我给你一些真正的例子......我有一个叫做哈珀的游戏,它已被播放了两次(所以数据库中有两个记录有时间).以下是它的时代:

beginSetup(1) = 2012-07-25 12:06:03
startPlay(1) = 2012-07-25 12:47:14
gameEnd(1) = 2012-07-25 13:29:45

beginSetup(2) = 2012-08-01 12:06:30
startPlay(2) = 2012-08-01 12:55:00
gameEnd(2) = 2012-08-01 13:40:32
Run Code Online (Sandbox Code Playgroud)

然后我运行你提供给我的查询(并将秒转换为小时/分钟/秒)我得到了这些结果(对不起,我不知道如何做你所做的酷表):

gameName = Harper
Total Time = 03:34:32
...and other incorrect numbers.
Run Code Online (Sandbox Code Playgroud)

从数字来看,平均总时间应该是大约1小时24分钟 - 而不是3小时34分钟.知道为什么我的数字不正确吗?

dre*_*010 6

这是一个查询,以获得每个游戏的平均设置时间和游戏时间,希望它有所帮助:

SELECT
  gameName,
  AVG(UNIX_TIMESTAMP(startPlay) - UNIX_TIMESTAMP(beginSetup)) AS setupTime,
  AVG(UNIX_TIMESTAMP(gameEnd) - UNIX_TIMESTAMP(startPlay)) AS gameTime,
  AVG(UNIX_TIMESTAMP(gameEnd) - UNIX_TIMESTAMP(beginSetup)) AS totalTime,
FROM `table`
GROUP BY gameName
ORDER BY totalTime DESC;
Run Code Online (Sandbox Code Playgroud)

应该产生的结果类似于:

+----------+-----------+-----------+-----------+
| gameName | setupTime | gameTime  | totalTime |
+----------+-----------+-----------+-----------+
| chess    | 1100.0000 | 1250.0000 | 2350.0000 |
| checkers |  466.6667 |  100.5000 |  933.3333 |
+----------+-----------+-----------+-----------+
Run Code Online (Sandbox Code Playgroud)

我刚刚插入了大约8个带有一些随机数据的测试行,所以我的数字没有意义,但这就是你得到的结果.

请注意,这将扫描整个表,因此可能需要一段时间,具体取决于此表中的记录数.如果你有相当数量的游戏记录,这肯定是你想要定期在后台运行的东西.