业务介绍
在日常的项目评标中,一个项目拥有多个专家,一个专家可以在多个项目中,此时专家和项目的业务逻辑为多对多,需要建立中间表来约束二者的关系。多对多可以用查询结果映射结果集,而不是使用子查询,但是如果使用结果映射会导致子表中的数据条数也会加到主表的条数中,导致mybatis的page插件中total总数出错,所以使用子查询规避了这个问题。
数据表
- 数据库中创建项目表
create table `project`(
`id` varchar(36),
`project_name` varchar(32),
`project_type` varchar(32),
PRIMARY KEY (`id`)
)
- 数据库中创建专家表
create table `professor`(
`id` varchar(36),
`professor_name` varchar(32),
`professor_type` varchar(32),
PRIMARY KEY (`id`)
)
- 数据库中创建项目专家中间表
create table