Mapper.xml映射文件

Mapper.xml映射文件:

<select> resultType如果返回的是集合,那么应该设置为集合包含的类型而不是集合本身的类型

如果参数类型是pojo类型,参数名必须是pojo中的属性名

<insert>

session.commit();

session = factory.openSession();

driver:com.mysql.jdbc.Driver

url:jdbc:mysql://127.0.0.1:3306/test

动态sql:

小于号

<![CDATA[<=]]>

:

XML 复制代码
<where>:
<if test="sal != null">
and sal <![CDATA[<=]]>#{sal}         //and,or会自动给去掉
</where>
XML 复制代码
choose when otherwise:
when otherwise中只走一个
select * from emp where
<choose>
    <when test="sal != null">
        sal <![CDATA[<=]]> #{sal}
    </when>
    <when test="ename != null">
        ename like concat('%',#{ename},'%')
    </when>
    <otherwise>
        deptno=#{deptno}
    <otherwise>
</choose>

trim标签 组合 if标签 主要功能 可以在自己包含的内容前面加上某些前缀,也可以在其后加上某些后缀,与之对应的属性是prefix和suffix;

可以把包含内容的首部某些内容覆盖,即忽略,也可以把尾部的某些内容覆盖,对应的属性是prefixOverrides和suffixOverrides

XML 复制代码
insert into emp
<trim prefix="("  suffix=")" suffixOverrides = ",">
    <if test = "empno != null">
        empno,
    <if test = "ename != null">
        ename,
    <if test = "mgr != null">
        mgr,
    <if test = "sal != null">
        sal,
    <if test = "deptno != null">
        deptnol,
</trim>
values
<trim prefix="("  suffix=")" suffixOverrides = ",">
    <if test = "empno !=null">
        #{empno},
    <if test = "ename != null">
        #{ename},
    <if test = "mgr != null">
        #{mgr},
    <if test = "sal != null">
        #{sal},
    <if test = "deptno != null">
        #{deptnol},
</trim>

<set>标签: 如果包含的语句以逗号结束会把逗号省略掉

XML 复制代码
update   emp
<set>
    <if test="sal != null">
        sal=#{sal},
    </if>
    <if test="mgr != null">
        mgr=#{mgr},
    </if>
    <if test="ename != null">
        ename=#{ename},
    </if>
</set>
<where>
    <if test="empno != null">
        and empno = #{empno}
    </if>
    <if test="job != null">
        and job =  #{job}
    </if>
</where>

<foreach>主要用在构建in条件中,它可以在SQL语句中迭代一个集合

item 表示集合中每一个元素进行迭代时的别名

index指定一个名字,用于表示在迭代过程中,每次迭代到的位置

LIST\]: ```XML select * from emp empno=#{empno} select * from emp where empno in #{empno} ``` \[array\]: paramaterType = List ```XML select * from emp where empno in #{empno} [map]: ``` (Map\ map\>) 多条件复杂查询的时候 List\ selectEmpByMapinfo(Map\); ```XML . ``` map.put("deptnokey",10) map.put("enamekey","enamekey") map.put(empnos,list) \[SQL片段\]: ```XML select * from emp ``` \[bind\]标签 ```XML ``` resultType实现一对一 多对多: ```XML ``` SqlSessionFactory factory; Inputstream stream = Resources.getResourceasStream("SqlMapConfig.xml"); factory = SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder().build(stream) page工具类实现分页:page工具类: PageHelper.startPage((page- 1)\* size,size)

相关推荐
qq_5470261798 小时前
Redis 常见问题
数据库·redis·mybatis
小北方城市网14 小时前
Spring Boot 多数据源与事务管理实战:主从分离、动态切换与事务一致性
java·开发语言·jvm·数据库·mysql·oracle·mybatis
小马爱打代码17 小时前
MyBatis:缓存体系设计与避坑大全
java·缓存·mybatis
alien爱吃蛋挞19 小时前
【JavaEE】万字详解Mybatis(上)
数据库·java-ee·mybatis
煎饼皮皮侠1 天前
设计一个分页插件之二【基于mybatis实现分页插件】
mybatis·分页插件
czlczl200209252 天前
MyBatis-Plus SQL自动填充字段
sql·tomcat·mybatis
独断万古他化2 天前
【MyBatis-Plus 进阶】注解配置、条件构造器与自定义 SQL的复杂操作详解
sql·mybatis·mybatis-plus·条件构造器
马猴烧酒.2 天前
【JAVA数据传输】Java 数据传输与转换详解笔记
java·数据库·笔记·tomcat·mybatis
962464i3 天前
mybatis-plus生成代码
java·开发语言·mybatis
小信丶3 天前
@MappedJdbcTypes 注解详解:应用场景与实战示例
java·数据库·spring boot·后端·mybatis