联表查询
创建数据库 data:image/s3,"s3://crabby-images/469be/469beb5c07692d72dcf941763288b5f23a8a2020" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/389b3/389b3e17b58e0b77ac42ed63fc638fd6e40b1347" alt="在这里插入图片描述"
多对一处理(关联 association)
创建实体类 data:image/s3,"s3://crabby-images/e4f18/e4f18eeaecf743fff3dddee4ee6df0f4c37163e1" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/f581e/f581eaf538c23d472edba65c58c355af95f0f510" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/640da/640da79360d748c22ba3cbbd8db6514f4dc95035" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f1f97/f1f97abec6be5f022ff9c6a83532a3dc1eb3d18c" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/d3056/d3056bb53f9da2d96389e426f402199ef48a9a22" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8e985/8e985320d8c613eb84ddfec3b4eb3b1c56ab6ce4" alt="在这里插入图片描述"
一对多处理(集合 collection)
data:image/s3,"s3://crabby-images/bfef4/bfef4e3b1a8fa708f87c479a6f16731716499397" alt="在这里插入图片描述"
按查询嵌套处理
<select id="getTeacher" resultMap="TeacherMap">
select * from teacher where id=#{tid}
</select>
<resultMap id="TeacherMap" type="teacher">
<result property="id" column="id"></result>
<result property="name" column="name"></result>
<collection property="students" column="id" javaType="ArrayList" ofType="Student" select="getStudent">
</collection>
</resultMap>
<select id="getStudent" resultType="student">
select * from student where tid=#{id}
</select>
按结果嵌套处理
<select id="getTeacher2" resultMap="teacherMap2">
select s.id sid,s.name sname,t.id tid,t.name tname
from student s,teacher t
where s.tid=t.id and t.id=#{tid}
</select>
<resultMap id="teacherMap2" type="teacher">
<result property="id" column="tid"></result>
<result property="name" column="tname"></result>
<collection property="students" javaType="ArrayList" ofType="student">
<result property="id" column="sid"></result>
<result property="name" column="sname"></result>
<result property="tid" column="tid"></result>
</collection>
</resultMap>
测试; data:image/s3,"s3://crabby-images/bf78d/bf78d7a9dbf3d00511946e87cb01e2f3ab0673f0" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d2471/d24713e71a1c3448c18f065e1939e17a2641bea4" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/1a1d3/1a1d32b2964230fdd1f5d74a1c73173a6d7324a2" alt="在这里插入图片描述"
动态sql
data:image/s3,"s3://crabby-images/8a5fd/8a5fd9159f37051d3a4310729d18f443e8873533" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d479a/d479af3f0f62e02c0a7d659e8fbba8ff26b1b645" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8865b/8865bf8d2c3086914dc5a210dc8d06562193476d" alt="在这里插入图片描述" 注:这里id类型写错了,应该为string
tip:编写一个IDUtils工具类,用于随机生成ID
data:image/s3,"s3://crabby-images/d9890/d989008e28fd73e4da90880475be2324757ece15" alt="在这里插入图片描述"
tip:要解决pojo中驼峰命名法属性名和数据库下划线命名法字段名不一致的问题(数据库采用下划线命名是因为数据库会将字段名全部转换为大写,所以用下划线命名) 在mybatis配置文件setting中配置
data:image/s3,"s3://crabby-images/ffbd2/ffbd2e6b8f4334c1c8b2d0e4a453cc0909a07650" alt="在这里插入图片描述"
if标签
data:image/s3,"s3://crabby-images/5490f/5490f987a8f8185d24e73b6ef23c4fdbf3b19e48" alt="在这里插入图片描述"
传入参数类型为map,如上述的title和author就是map中的key;#{title}就是对应的value
choose 标签
choose when otherwise相当于java中的switch case default data:image/s3,"s3://crabby-images/e0f4c/e0f4c8e02d563bf575f9f5ecff7cdac699bfa426" alt="在这里插入图片描述"
trim(where set)标签
data:image/s3,"s3://crabby-images/1a0fd/1a0fdbf78bf1a9993dffedcdbf33aa9efac86435" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/20979/209795e831489d30494bee18b72950622b3a7f28" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/a0cf6/a0cf6b12cecb408276acfd6681ba38fa1844dc84" alt="在这里插入图片描述"
trim可以定制化where和set,不过用的也不多,需要时参考文档即可
调用举例
data:image/s3,"s3://crabby-images/24ef4/24ef4c1fa17f794958be1a7e39852350adccf981" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/90580/905800227c04f6dc85d5ff31709e37b1ab4b056d" alt="在这里插入图片描述"
sql片段
data:image/s3,"s3://crabby-images/166de/166de5649084e5fed93af33107d1a9188374c332" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/323bd/323bd0a15304651623d15fbf924f9b95f7a24ffe" alt="在这里插入图片描述"
foreach 标签
data:image/s3,"s3://crabby-images/14b5e/14b5eac57c3deb77c65409e89108b8dd1f1562e8" alt="在这里插入图片描述"
collectin:map中传入的用于遍历的集合 item:集合中的每一项 index:下标,一般不用 open:开始符号 close:结束符号 separator:每一项中间的分隔符
foreach常用于in/or查询
举例如下
or查询
<select id="BlogForEach" parameterType="map" resultType="blog">
select * from blog
<where>
<foreach collection="ids" item="id" open="(" close=")" separator="or">
id=#{id}
</foreach>
</where>
</select>
in查询
<select id="BlogForEach" parameterType="map" resultType="blog">
select * from blog where id in
<foreach collection="ids" item="id" open="(" close=")" separator=",">
#{id}
</foreach>
</select>
data:image/s3,"s3://crabby-images/e9a16/e9a166c2d45086f7fdb81f3b0ec238bab0b9ecc6" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/2eba3/2eba3f7e69cff287afc9da71521b377e2c0a47a3" alt="在这里插入图片描述"
|