- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了左连接的挑战,它给我带来了很多结果。我想列出比赛中的获胜者。在我的获奖者表中,我有 id、比赛、图片、地点、发布。感谢我能得到的任何帮助! :-)
$id 返回当前比赛 ID。
在我的示例中,winners 表只有 3 行,但返回 9 行。
这是我的查询:
$sql = "SELECT
photocontest_winners.id,
photocontest_winners.contest,
photocontest_winners.image,
photocontest_winners.place,
photocontest_entries.id,
photocontest_entries.contest,
photocontest_entries.name,
photocontest_entries.title,
photocontest_entries.image
FROM photocontest_winners
LEFT JOIN photocontest_entries ON photocontest_winners.contest = photocontest_entries.contest
WHERE photocontest_winners.contest = $id AND photocontest_winners.published = 1
ORDER BY photocontest_winners.place";
$result = $conn->query($sql);
while($row = $result->fetch_assoc()) {
echo("<pre>");
print_r($row);
echo("</pre>");
}
这是一个示例输出(我不明白为什么每个图像在“位置”中都有 int 1、2 和 3,因为我在数据库中的表现不一样。:
Array
(
[id] => 1
[contest] => 2
[image] => dummy-item.jpg
[place] => 1
[name] => Daniel
[title] => aar
)
Array
(
[id] => 3
[contest] => 2
[image] => dummy-item.jpg
[place] => 1
[name] => Peter
[title] => Andet billede
)
Array
(
[id] => 4
[contest] => 2
[image] => dummy-item.jpg
[place] => 1
[name] => Lucas
[title] => Andet billede test
)
Array
(
[id] => 1
[contest] => 2
[image] => dummy-item.jpg
[place] => 2
[name] => Daniel
[title] => aar
)
Array
(
[id] => 3
[contest] => 2
[image] => dummy-item.jpg
[place] => 2
[name] => Peter
[title] => Andet billede
)
Array
(
[id] => 4
[contest] => 2
[image] => dummy-item.jpg
[place] => 2
[name] => Lucas
[title] => Andet billede test
)
Array
(
[id] => 1
[contest] => 2
[image] => dummy-item.jpg
[place] => 3
[name] => Daniel
[title] => aar
)
Array
(
[id] => 3
[contest] => 2
[image] => dummy-item.jpg
[place] => 3
[name] => Peter
[title] => Andet billede
)
Array
(
[id] => 4
[contest] => 2
[image] => dummy-item.jpg
[place] => 3
[name] => Lucas
[title] => Andet billede test
)
带有样本数据的比赛表:
SET NAMES utf8;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for `photocontest_contests`
-- ----------------------------
DROP TABLE IF EXISTS `photocontest_contests`;
CREATE TABLE `photocontest_contests` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`title` varchar(255) DEFAULT NULL,
`description_image` varchar(255) DEFAULT NULL,
`prize_image` varchar(255) DEFAULT NULL,
`intro` text,
`prizes` text,
`rules` text,
`privacy_policy` text,
`time_start` datetime DEFAULT NULL,
`time_end` datetime DEFAULT NULL,
`published` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of `photocontest_contests`
-- ----------------------------
BEGIN;
INSERT INTO `photocontest_contests` VALUES ('1', 'Contest 1', 'dummy-cat.jpg', 'dummy-prize.jpg', 'EOS 5D Mark III er et fullframe digitalt spejlreflekskamera med 22,3 Megapixel, autofokus med 61 punkter samt 6 bps kontinuerlig optagelse. Optag Full HD-film i høj kvalitet, og hav fuld manuel kontrol over alt lige fra billedhastighed til lyd.', '<div class=\"row\">\n <div class=\"prize odd\">\n <div class=\"prize-desc\"><h3>1. Præmie</h3><p>EOS 5D Mark III er et fullframe digitalt spejlreflekskamera med 22,3 Megapixel, autofokus med 61 punkter samt 6 bps kontinuerlig optagelse. Optag Full HD-film i høj kvalitet, og hav fuld manuel kontrol over alt lige fra billedhastighed til lyd.</p></div>\n <div class=\"prize-image\">\n <img src=\"images/dummy-prize.jpg\" alt=\"\" />\n </div>\n <div class=\"clr\"></div>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"prize even\">\n <div class=\"prize-desc\"><h3>2. Præmie</h3><p>EOS 5D Mark III er et fullframe digitalt spejlreflekskamera med 22,3 Megapixel, autofokus med 61 punkter samt 6 bps kontinuerlig optagelse. Optag Full HD-film i høj kvalitet, og hav fuld manuel kontrol over alt lige fra billedhastighed til lyd.</p></div>\n <div class=\"prize-image\">\n <img src=\"images/dummy-prize.jpg\" alt=\"\" />\n </div>\n <div class=\"clr\"></div>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"prize odd\">\n <div class=\"prize-desc\"><h3>3. Præmie</h3><p>EOS 5D Mark III er et fullframe digitalt spejlreflekskamera med 22,3 Megapixel, autofokus med 61 punkter samt 6 bps kontinuerlig optagelse. Optag Full HD-film i høj kvalitet, og hav fuld manuel kontrol over alt lige fra billedhastighed til lyd.</p></div>\n <div class=\"prize-image\">\n <img src=\"images/dummy-prize.jpg\" alt=\"\" />\n </div>\n <div class=\"clr\"></div>\n </div>\n </div>', 'rules', 'privacy', '2015-05-12 14:18:02', '2015-05-28 14:18:07', '1'), ('2', 'Contest 2', 'dummy-cat.jpg', 'dummy-prize.jpg', '2 EOS 5D Mark III er et fullframe digitalt spejlreflekskamera med 22,3 Megapixel, autofokus med 61 punkter samt 6 bps kontinuerlig optagelse. Optag Full HD-film i høj kvalitet, og hav fuld manuel kontrol over alt lige fra billedhastighed til lyd.', '<div class=\"row\">\n <div class=\"prize odd\">\n <div class=\"prize-desc\"><h3>1. Præmie</h3><p>EOS 5D Mark III er et fullframe digitalt spejlreflekskamera med 22,3 Megapixel, autofokus med 61 punkter samt 6 bps kontinuerlig optagelse. Optag Full HD-film i høj kvalitet, og hav fuld manuel kontrol over alt lige fra billedhastighed til lyd.</p></div>\n <div class=\"prize-image\">\n <img src=\"images/dummy-prize.jpg\" alt=\"\" />\n </div>\n <div class=\"clr\"></div>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"prize even\">\n <div class=\"prize-desc\"><h3>2. Præmie</h3><p>EOS 5D Mark III er et fullframe digitalt spejlreflekskamera med 22,3 Megapixel, autofokus med 61 punkter samt 6 bps kontinuerlig optagelse. Optag Full HD-film i høj kvalitet, og hav fuld manuel kontrol over alt lige fra billedhastighed til lyd.</p></div>\n <div class=\"prize-image\">\n <img src=\"images/dummy-prize.jpg\" alt=\"\" />\n </div>\n <div class=\"clr\"></div>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"prize odd\">\n <div class=\"prize-desc\"><h3>3. Præmie</h3><p>EOS 5D Mark III er et fullframe digitalt spejlreflekskamera med 22,3 Megapixel, autofokus med 61 punkter samt 6 bps kontinuerlig optagelse. Optag Full HD-film i høj kvalitet, og hav fuld manuel kontrol over alt lige fra billedhastighed til lyd.</p></div>\n <div class=\"prize-image\">\n <img src=\"images/dummy-prize.jpg\" alt=\"\" />\n </div>\n <div class=\"clr\"></div>\n </div>\n </div>', 'rules', 'privacy', '2015-05-12 14:18:02', '2015-05-12 14:18:07', '1');
COMMIT;
SET FOREIGN_KEY_CHECKS = 1;
带有示例数据的条目表
SET NAMES utf8;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for `photocontest_entries`
-- ----------------------------
DROP TABLE IF EXISTS `photocontest_entries`;
CREATE TABLE `photocontest_entries` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`contest` int(11) DEFAULT NULL,
`name` varchar(255) DEFAULT NULL,
`email` varchar(255) DEFAULT NULL,
`phone` varchar(255) DEFAULT NULL,
`title` varchar(255) DEFAULT NULL,
`description` text,
`image` varchar(255) DEFAULT NULL,
`published` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of `photocontest_entries`
-- ----------------------------
BEGIN;
INSERT INTO `photocontest_entries` VALUES ('1', '2', 'Daniel', 'my@email.com', '12345678', 'aar', '', 'dummy-item.jpg', '1'), ('2', '1', 'Hans', 'my@email.com', '12345678', 'Mit Billede', 'Dette er en fed beskrivelse', 'dummy-item.jpg', '1'), ('3', '2', 'Peter', 'my@email.com', '12345678', 'Andet billede', 'Dette er en fed beskrivelse', 'dummy-item.jpg', '1'), ('4', '2', 'Lucas', 'my@email.com', '12345678', 'Andet billede test', 'beskrivelse', 'dummy-item.jpg', '1'), ('5', '1', 'Ditte', 'my@email.com', '12345678', 'Billede titel', 'Anden beskrivelse', 'dummy-item.jpg', '1');
COMMIT;
SET FOREIGN_KEY_CHECKS = 1;
带有示例数据的获胜者表:
SET NAMES utf8;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for `photocontest_winners`
-- ----------------------------
DROP TABLE IF EXISTS `photocontest_winners`;
CREATE TABLE `photocontest_winners` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`contest` int(11) NOT NULL,
`image` int(11) DEFAULT NULL,
`place` int(11) DEFAULT NULL,
`published` tinyint(4) DEFAULT '0',
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
-- ----------------------------
-- Records of `photocontest_winners`
-- ----------------------------
BEGIN;
INSERT INTO `photocontest_winners` VALUES ('1', '2', '1', '1', '1'), ('4', '2', '3', '2', '1'), ('5', '2', '4', '3', '1');
COMMIT;
SET FOREIGN_KEY_CHECKS = 1;
最佳答案
我认为如果您还告诉我们每个表的列名称和它们的 1-2 个条目行,会更全面。在此之后,我可以想出可能会出现什么问题。
我的第一个猜测是你用来左连接的键
JOIN photocontest_entries ON photocontest_winners.contest = photocontest_entries.contest
它不是唯一的。在您的其中一个表中,photocontest_winners.contest 与其他表记录 photocontest_entries.conteststrong text 有多个匹配项。或者反过来……
关于php - 左连接 - 返回许多结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30484764/
这个问题已经有答案了: Declaring multiple object pointers on one line causes compiler error (5 个回答) 已关闭 6 年前。 l
我目前正在学习语言处理器,经常出现的一个话题是语法中元素的使用方向。从左到右或从右到左。 我理解这个概念,但似乎有很多方法可以编写这些规则,我不确定它们是否都相同。到目前为止我看到的是: 右/左递归,
我有一个很长的线性(分支不多)流程图,在 graphviz 中显示为要么太高而无法放在单个页面上,要么太宽(如果方向是从左到右) 是否有一种简单的方法可以让 graphviz 以从左到右,然后向下,然
我一直摸不着头脑,但运气不好。设计器有一个包含 3 栏的站点、两个侧边栏和一个主要内容区域。 专为桌面设计,左栏、主要内容、右栏。但是,在较小的设备上,我们希望首先堆叠主要内容。 所以通常情况下,你可
我想要从上到下和从左到右组织的 css block 。 为了更好地解释这是一张图片,其中包含我到目前为止所获得的内容以及我希望使用 CSS 实现的内容: 代码如下: HTML: 1 2 3 4 5
当我问this question时,答案之一(现已删除)建议Either类型对应Curry-Howard correspondence中的XOR而不是OR,因为它不能同时是Left和Right。 真相
我有一个程序,如果用户按住向左或向右箭头键, Angular 色会逐渐朝那个方向加速,并最终达到最大速度。松开按键后, Angular 色逐渐减速,直至完全停止。 我的右方向键没问题,但左方向键坏了。
今天很简单的一个。我有一个专栏,我们称之为标题,有一堆项目标题。我需要从“:”的左侧拉出所有内容并进行左/右修剪(稍后我将在连接中使用它,但我现在只需要一个包含新数据的列) .下面是当前列的示例: 这
我正在尝试将图表中的列与左侧对齐。默认情况下,它们位于中间。 我在 API 文档中找不到任何关于此的信息。 Here是一个 jsFiddle 测试。 最佳答案 在 highcharts api 中,您
左旋转进位和右旋转进位指令有哪些实际用途? 在我的汇编课上,我们无法想出一个有用的好例子。 最佳答案 如果您想将位从一个操作数移出并移入另一个操作数: SHL EAX, 1 ; mov
我有一个查询,它使用 eqjoin 从两个不同的表返回以下数据。我想将 left 和 right 结合起来,而不是执行 zip() (重写 name > 和 joined_at),我想将右侧对象的属性
我使用 firebase API。发送和检索消息。但是,我在尝试为发送者/检索者设置布局时遇到麻烦,以便消息将左/右对齐。目前我只有发送者/检索者都使用的一种布局,但不确定如何设置不同的布局。 pub
我的菜单基本上是一个水平项目滑动条。所有菜单项都有特定的默认 CSS 属性。我希望这些项目在到达主容器的中心时更改其大小和左/右边距,并在离开主容器(或位于主容器之外)时重置为默认值。请参阅我的原理图
我有一个引用表,在这个表中有 3 个字段(Id、User1、User2)。 User2 字段可以为空,但我们在不使用时使用 0。 当我执行下面的 Linq 查询时,User2 == 0 的记录不是结果
不知道如何解决这个问题。 我有两个表结果和受访者 我需要查明受访者表中是否有任何行具有completion =“Complete”,但它们的respondent_id(在结果表和受访者表中)不在结果表
我正在尝试访问三个表以获得类似这样的内容: +------+------+------+ | ITEM | PCS | CSS | +------+------+------+ | 1099 |
left 和 right join 有区别吗,下面的sql 语句结果一样,但是两者的性能是一样的吗? SELECT count(*) FROM writers RIGHT JOIN blogs O
当我使用 LEFT() 使用以下代码从数据库中获取值时 $select="SELECT LEFT(description,500) FROM tbl_news where id='$id'"; $qu
当我将鼠标悬停在水平导航菜单上的页面名称上时,相关子页面会 float 在下方。 目前这些显示居中,我如何对齐它们以便它们向左对齐(与导航菜单标题名称一致)。 你可以去看到这个 http://79.1
在下面的引导网格示例中,它使用 col-sm 和 col-sm-push/pull。col-sm-push 指定了左/右值(偏移量)。 我不太清楚它是如何工作的。 第二个 float 元素来到第一个
我是一名优秀的程序员,十分优秀!