繁体   English   中英

查询仅显示一个结果

[英]Query only displaying one result

我有以下查询,一直以来我都认为我的while循环无法正常工作,但事实证明我的查询仅输出一条记录。

SELECT up.ordering, u.id, u.username, up.playername 
FROM users AS u 
INNER JOIN playersByUser AS up ON u.id = up.userid 
WHERE u.group IN (3,4,5)
ORDER BY up.ordering

它应该输出多个,但我不确定为什么只能输出一个。 我正在尝试从用户表中的组为5的用户和playersByUser表中选择ID。 然后输出用户名。

playersByUser

CREATE TABLE `playersByUser` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `userid` int(11) DEFAULT NULL,
 `playername` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
 `ordering` tinyint(4) DEFAULT NULL,
 PRIMARY KEY (`id`),
 KEY `userid` (`userid`),
 CONSTRAINT `playersByUser_ibfk_1` FOREIGN KEY (`userid`) REFERENCES `users` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

使用者

CREATE TABLE `users` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `firstname` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
 `lastname` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
 `email` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
 `phone_number` varchar(15) COLLATE utf8_unicode_ci NOT NULL,
 `username` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
 `password` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
 `salt` varchar(32) COLLATE utf8_unicode_ci NOT NULL,
 `joined` datetime NOT NULL,
 `group` int(11) NOT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=95 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_c

可以使用的数据是这样的:

使用者

id  firstname lastname   email            phone_number username  password salt   joined    group
1   name1     lastname1  email@email.com  555-555-5555 testSQL   fdfdf     acc     9-3-15   5
2   name2     lastname2  email2@email.com 555-555-5556 testSQL2  fdfdf     dcc     9-3-15   5

playersByUser

id userid playername ordering
1    1        Bob       1
2    2        Dave      1

您是否尝试过重命名users.group字段? 您是否还尝试过左联接,以防联接表上不存在数据?

SELECT playersByUser.ordering, users.id, users.username, playersByUser.playername 
   FROM users, playersByUser where users.id = playersByUser.userid 
   AND `users.group` IN (3,4,5)
   ORDER BY playersByUser.ordering

在phpMyAdmin中对我工作正常

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM