四天学会Mybatis

Mybatis第三天

动态sql:

if

<if test=”判断java对象的属性值”>
部分sql语句
</if>

在接口中定义方法(注意)使用动态sql时必须把对象作为参数
在这里插入图片描述
配置文件中写入select
在这里插入图片描述

If里的判断条件为参数的属性值判断 满足将会将if节点里的部分sql语句拼接到上面的sql语句中

【在上图中,因为在if中如果只有第一个条件满足或只有第二个条件满足,拼接上字符串会造成sql语法错误,所以我们在where后面加上了1=1】

where

作用: 【当where中的if语句只要有一个满足,便会自动加上where以及相关语句】
Where一般【配合】if使用;【可以解决之前的if拼接问题】就可以不用在sql语句后面加入where 1=1了。 接口中写入方法

在这里插入图片描述

写入配置文件
在这里插入图片描述
foreach

Forraach实现list,array的循环,实现动态sql
一般用于这种情况,
Select * from stuinfo where sno in(“1”,”2”,”4”);
而后面的in可以用foreach实现
写入接口方法:

在这里插入图片描述
在这里插入图片描述

3.sql代码片段
作用:复用sql语句;
步骤:
在mapper文件(次配置文件)中,
先定义:<sql id=”自定义”>sql语句</sql>
再在select或者insert中引入sql语句
<include refid=”之前的sql节点中的id” />

Mybatis多表查询

一对一

首先要在实体类中加入属性,这个属性是你要包含的一对一关系。 在mapper文件中写入resultmap对应一对一

在这里插入图片描述
一对多

首先要在实体类中加入属性,这个属性是你要包含的一对多关系的list集合。 在mapper文件中写入resultmap对应一对多
在这里插入图片描述
注意:sql语句很重要

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值