【问题标题】:Query only displaying one result查询只显示一个结果
【发布时间】:2015-09-03 18:44:13
【问题描述】:

我有以下查询,我一直认为我的 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

它应该输出几个,我不确定为什么它只得到一个。我正在尝试从 users 和 playerByUser 表中选择 id,其中用户表中的组为 5。然后输出用户名。

玩家按用户

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

玩家按用户

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

【问题讨论】:

  • 不,它不会失败,当我引用它时,它会做同样的事情。
  • 您甚至没有获取结果的语句,而只有 prepare。您是逐行获取它吗?还可以考虑使用 sqlfiddle 为那些尝试回答的人节省时间。
  • 我正在 phpmyadmin 中测试这个,因为我的循环和 fetch 正在工作。它正在输出 sql 提取的内容,这只是一条记录。我的问题是问题。我从未使用过 sqlfiddle。
  • 如果问题是SQL 为什么不只发布查询和表格?我们还需要表中的数据以及该查询的结果是什么,以查看问题所在。让问题尽可能简单How to create a Minimal, Complete, and Verifiable example.
  • @Becky 很高兴你把它整理好了。由于您的两个问题都没有对答案投赞成票,并且内容是转移注意力,您可以考虑删除它们。

标签: php mysql sql select


【解决方案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 中对我来说很好

【讨论】:

  • 这引发了一个错误,所以我这样做了.. users.group。它仍然只带出了一个用户。
猜你喜欢
  • 2012-05-13
  • 2021-02-24
  • 2017-01-19
  • 1970-01-01
  • 2011-07-26
  • 2019-04-17
  • 2017-12-12
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多