MyBatis-多表查询-一对一查询(方式一)
data:image/s3,"s3://crabby-images/2fee6/2fee676cdba22f2c2cd7952007707f86b3558af2" alt=""
data:image/s3,"s3://crabby-images/199fd/199fde5ecc6f5019319a8db8230c38edb001655b" alt=""
一个菜品对应一个分类
直接菜品记录category对象
data:image/s3,"s3://crabby-images/2e246/2e246c84a837aa89b0f8b580c90dfc0146b0317c" alt=""
菜品id写入Dish,后面的分类直接写入 Category类
封装,如果sql不能封装上,那么直接使用resultmap封装
使用resultType只能封装基本属性
所以要定义一个resultmap手动封装
使用标签
要有id
使用resultmap 进行 一对一的封装
MyBatis-多表查询-一对一查询(方式二)
使用别名 : 别名就是类名的简写 首字母写法都可以 不区分大小写
当在peoperties中配置别名之后,直接写别名就可以
总结
Mybatis的多表查询 1对1
首先 1对1查询 ,
首先在pojo实体类中先声明出另一个对象的属性
data:image/s3,"s3://crabby-images/18486/18486cd6a25165767a358776d01c120d0a1a9107" alt=""
因为是1对1查询
然后按照mybatis的三步约定
第一 同包同名 mapper接口要与mapper.xml所在的包的路径要相同 ,并且名字要一样
第二个 mapper.xml的namespace的地址要写 mappe的全类名
第三个mapper.xml的id要与mapper的方法名要一致
data:image/s3,"s3://crabby-images/5bf14/5bf149e058f873698da2468cc95c5e52ca028f9d" alt=""
java是与resource是同一级的
都在main的下面
main的下面只有 java与resource
mybatis的使用
mybatis的使用首先要配置数据库的参数
data:image/s3,"s3://crabby-images/4321b/4321bc3e7ab58741188cc8cafe29bd3f989b2233" alt=""
mybatis的驼峰映射也要开启,不用设计参数名了
然后进行sql的书写
data:image/s3,"s3://crabby-images/018ea/018ea7075c51873a98c5ee940a2cf6a67e23b7ba" alt=""
这个是多表的查询所以,在一个resultmap中是查询的引用对象
resulttype是查询的简单数据
使用resultMap
sql
<resultMap id="dishMap1" type="dish">
<id column="id" property="id"></id>
<result column="name" property="name"></result>
<result column="category_id" property="categoryId"></result>
<result column="price" property="price"></result>
<result column="image" property="image"></result>
<result column="description" property="description"></result>
<result column="status" property="status"></result>
<result column="create_time" property="createTime"></result>
<result column="update_time" property="updateTime"></result>
<result column="cid" property="category.id"></result>
<result column="cname" property="category.name"></result>
<result column="ctype" property="category.type"></result>
<result column="csort" property="category.sort"></result>
<result column="cstatus" property="category.status"></result>
<result column="ccreate_time" property="category.createTime"></result>
<result column="cupdate_time" property="category.updateTime"></result>
</resultMap>
这是第一种方式,
直接列对应属性,
第二种方式使用association
sql
<resultMap id="dishMap2" type="Dish">
<id column="id" property="id"></id>
<result column="name" property="name"></result>
<result column="category_id" property="categoryId"></result>
<result column="price" property="price"></result>
<result column="image" property="image"></result>
<result column="description" property="description"></result>
<result column="status" property="status"></result>
<result column="create_time" property="createTime"></result>
<result column="update_time" property="updateTime"></result>
<association property="category" javaType="com.healer.pojo.Category">
<id column="cid" property="id"></id>
<result column="cname" property="name"></result>
<result column="ctype" property="type"></result>
<result column="csort" property="sort"></result>
<result column="cstatus" property="status"></result>
<result column="ccreate_time" property="createTime"></result>
<result column="cupdate_time" property="updateTime"></result>
</association>
</resultMap>
<!-- 查询菜品,同时查询出菜品所示的分类-->
<select id="findAlldishWithCategory" resultMap="dishMap2">
select d.*,
c.id cid,
c.name cname,
c.type ctype,
c.sort csort,
c.status cstatus,
c.create_time ccreate_time,
c.update_time cupdate_time
from dish d
left join category c on d.category_id = c.id;
</select>
列对应着属性
如果想要简写,可以使用
java
#指定Mybatis的实体目录
mybatis.type-aliases-package=com.healer.pojo
然后就可以写别名
在association中
使用javaType
data:image/s3,"s3://crabby-images/7c5a7/7c5a76b1d235e1b919a5fa89bb798e6bff139b11" alt=""
Mybatis-多表查询-一对多查询
data:image/s3,"s3://crabby-images/79581/79581694cae1b079cea7e6defcae204ba916db0d" alt=""
查询的数据往分类里面封装
既然一个分类里面的基本信息不能满足需求了
使用集合 在pojo中定义一个集合
data:image/s3,"s3://crabby-images/8f0ae/8f0aeda327f6d591afe36e97382326bceb5ca9dc" alt=""
多对多的查询
data:image/s3,"s3://crabby-images/71b42/71b42277033410a51ae69cebd1f3b2dc4ac7811c" alt=""
保持原则
查询的数据要往哪个表中去封装
总结
不用记什么多对多,一对多 ,一对一
只需要记住使用resultmap
什么什么封装的
下面id写
然后其他的使用result
遇到对象了使用association , javaType
遇到集合了使用collection , ofType