合并2个表用于SELECT查询?

nks*_*tan 4 mysql database merge join

首先..这里是我创建的两个表(没有相关的列)...

CREATE TABLE users_history1 (
  circuit tinyint(1) unsigned NOT NULL default '0',
  userh_season smallint(4) unsigned NOT NULL default '0',
  userh_userid int(11) unsigned NOT NULL default '0',
  userh_rank varchar(2) NOT NULL default 'D',
  userh_wins int(11) NOT NULL default '0',
  userh_losses int(11) NOT NULL default '0',
  userh_points int(11) NOT NULL default '1000',
  KEY (circuit, userh_userid),
  KEY (userh_season)
) ENGINE=MyISAM;

CREATE TABLE users_ladders1 (
  circuit tinyint(1) unsigned NOT NULL default '0',
  userl_userid int(11) unsigned NOT NULL default '0',
  userl_rank char(2) NOT NULL default 'D',
  userl_wins smallint(3) NOT NULL default '0',
  userl_losses smallint(3) NOT NULL default '0',
  userl_points smallint(4) unsigned NOT NULL default '1000',
  PRIMARY KEY (circuit, userl_userid),
  KEY (userl_userid)
) ENGINE=MyISAM;
Run Code Online (Sandbox Code Playgroud)

一些背景......这些表格包含竞争阶梯的数据,其中玩家在点数的有序排名上相互比较.users_history1是一个包含以前季节存储的记录的表.users_ladders1包含当前季节的记录.我正在尝试在我的网站上创建一个页面,其中玩家按其先前记录和当前记录的平均点进行排名.以下是1v1阶梯的主要排名:http: //vilegaming.com/league.x/standings1/3

我想从两个表中的数据库中选择一个有序列表播放器,具体取决于他们的users_ladders1和users_history1记录的平均点数.我真的不知道如何从一个查询中的两个表中进行选择,但我会尝试尽可能通用,来说明它.

在整个示例中使用连字符,因为SO使它变得奇怪.

SELECT userh-points 
FROM users-history1 
GROUP BY userh-userid 
ORDER BY (total userh-points for the user)
Run Code Online (Sandbox Code Playgroud)

需要GROUP BY,因为有些球员可能在之前的多个赛季打过球.

SELECT userl-points 
FROM users-ladders1 
ORDER BY userl-points
Run Code Online (Sandbox Code Playgroud)

我希望能够在查询中组合两个表,以便我可以按总点数排序的行获取数据,如果可能的话,还可以将总点数除以播放器的唯一记录数,这样我就可以获得平均值.

sgr*_*usa 15

你会想要使用UNION SELECT:

SELECT p.id, COUNT(p.id), SUM(p.points)
FROM (SELECT userh_userid AS id, userh_points AS points
      FROM users_history1
      UNION SELECT userl_userid, userl_points
      FROM users_ladders1) AS p
GROUP BY p.id
Run Code Online (Sandbox Code Playgroud)

子查询是重要的部分.它将为您提供一个表,其中包含当前表和历史表的结果.然后,您可以从该表中进行选择,并执行COUNT和SUM以获得平均值.

我的MySQL语法很生疏,请原谅.我没有机会运行它,所以我甚至不确定它是否执行,但它应该足以让你开始.