在上一篇中我们介绍了mybatis如何实现一对多的功能,下面我们为大家介绍一下如何实现多对多功能
用户 User表里面的代码:
首先我们创建本篇所需要的数据库表,user为用户表,grouper为用户组表,而user_group表则是关联表用来将前面两张表的关系关联起来,表结构与插入的sql语句如下:
CREATE TABLE `user` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`username` varchar(64) NOT NULL DEFAULT '',
`mobile` varchar(16) NOT NULL DEFAULT '',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
INSERT INTO `user` VALUES ('1', 'yiibai', '13838009988');
INSERT INTO `user` VALUES ('2', 'User-name-1', '13838009988');
CREATE TABLE `grouper` (
`group_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`group_name` varchar(254) NOT NULL DEFAULT '',
PRIMARY KEY (`group_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
INSERT INTO `grouper` VALUES ('1', 'Group-1');
INSERT INTO `grouper` VALUES ('2', 'Group-2');
CREATE TABLE `user_group` (
`user_id` int(10) unsigned NOT NULL DEFAULT '0',
`group_id` int(10) unsigned NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO `user_group` VALUES ('1', '1');
INSERT INTO `user_group` VALUES ('2', '1');
INSERT INTO `user_group` VALUES ('1', '2');
第二步编写各个表所对应的实体类,其中User类加上一个List<Grouper>的方法用于在查询后接收查询多对应的值,而Grouper类也一样不过是加上List<User>而已,User_group则不变
用户 User表里面的代码:
package com.zhiyuan.com;
import java.util.List;
public class User {
private int id;
private String username;
private String mobile;
private List<Grouper> grouper;
public List<Grouper> getGrouper() {
return grouper;
}
public void setGrouper(List<Grouper> grouper) {
this.grouper = grouper;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
pu