热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mysql一对多,怎么返回join表的第一条记录

现在有主表A,附表B,AB关系为1对N。现在如何查询,能返回主表记录和附表记录和第一条或者最后一条记录。selecta.*fromaleftjoinbonb.a_ida
现在有主表A,附表B,AB关系为1对N。

现在如何查询,能返回主表记录和附表记录和第一条或者最后一条记录。

select a.* from a

left join b on b.a_id = a.id;

group by b.a_id;

10 个解决方案

#1


贴建表及插入记录的SQL,及要求结果出来看看

#2


业务就是记录管理的每次操作,需求就是返回管理员最后一次的操作



SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for `a`
-- ----------------------------
DROP TABLE IF EXISTS `a`;
CREATE TABLE `a` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

-- ----------------------------
-- Records of a
-- ----------------------------
INSERT INTO `a` VALUES ('1', 'admin');
INSERT INTO `a` VALUES ('2', 'guest');
INSERT INTO `a` VALUES ('3', 'demo');

-- ----------------------------
-- Table structure for `b`
-- ----------------------------
DROP TABLE IF EXISTS `b`;
CREATE TABLE `b` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `a_id` int(11) NOT NULL,
  `action` varchar(10) COLLATE utf8_unicode_ci NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

-- ----------------------------
-- Records of b
-- ----------------------------
INSERT INTO `b` VALUES ('1', '1', 'login');
INSERT INTO `b` VALUES ('2', '1', 'insert');
INSERT INTO `b` VALUES ('3', '1', 'delete');
INSERT INTO `b` VALUES ('4', '3', 'auth');


#3


结果是什么?

#4


假设B中ID唯一
SELECT * FROM b b1 LEFT JOIN a b2 ON b1.a_id=b2.id
WHERE NOT EXISTS(SELECT 1 FROM b WHERE b1.a_id=a_id AND b1.id

#5


假设以B中ID作为操作顺序标准

#6


引用 3 楼 wwwwa 的回复:
结果是什么?


结果是按A表查询出所有用户的B记录。

#7


引用 6 楼 vus520 的回复:
引用 3 楼 wwwwa 的回复:

结果是什么?


结果是按A表查询出所有用户的B记录。

用你的数据,结果是什么

#8


引用 7 楼 wwwwa 的回复:
引用 6 楼 vus520 的回复:
引用 3 楼 wwwwa 的回复:

结果是什么?


结果是按A表查询出所有用户的B记录。

用你的数据,结果是什么



1 admin 1 1 login
2 guest
3 demo 4 3 auth

#9


SELECT * FROM a b2 LEFT JOIN b b1 ON b1.a_id=b2.id
WHERE NOT EXISTS(SELECT 1 FROM b WHERE b1.a_id=a_id AND b1.id>id) 

#10


引用 9 楼 wwwwb 的回复:
SELECT * FROM a b2 LEFT JOIN b b1 ON b1.a_id=b2.id
WHERE NOT EXISTS(SELECT 1 FROM b WHERE b1.a_id=a_id AND b1.id>id)


看结果应该是差不多了,如果是获取最后一后操作呢。

推荐阅读
author-avatar
来自星星的小小鱼
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有