mybatis_02:Mapper.xml映射文件的写法

${}和#{}的用法区分:

${}表示拼接字符串,通过${}可以将parameterType传入的
内容拼接在sql中且不进行jdbc类型转换,${}可以接收简单
类型值或pojo属性值,如果parameter传输的是单个简单类
型值,${}括号内只能是value

#{}表示一个占位符,通过#{}向占位符中设置值,自动进行
java类型和jdbc类型转换,#{}可以有效防止sql注入。#{}可
以接收简单类型值或pojo属性值,如果parameterType传输
单个简单类型值,#{}括号内可以是value或其他名称

${}
如果传入的是基础数据类型; 大括号中只能写一个叫做value, 也就是说${value};
如果传入的pojo或者map类型, 那么只能写属性名或key名:${username};
存在sql注入的风险。

#{}
如果传入的是字符串;预编译时会自动带上单引号'
不存在sql注入的风险。

4165335-adf827114540e6f3.png
${}连词符-会导致潜在的sql注入风险.png

唯一性id返回

primary key return
前提是数据库得支持 auto-generated key fields

http://www.mybatis.org/mybatis-3/sqlmap-xml.html

4165335-4178e2053a09d229.png
image.png

keyProperty="id"
id是pojo的一个属性, 最终把被插入的行数是存放在id属性的。

当插入多行 id是数组类型的,或者是List类型的。

<selectKey>
数据库不支持 auto-generated key fields,就生成随机数

http://www.mybatis.org/mybatis-3/sqlmap-xml.html

4165335-2f23ca765d8d7947.png
image.png

resultMap和resultType

resultType

注意如果是List集合,那应该是集合可以包含的类型,而不能是集合本身。

public interface UserMapper {
    List<User> findUserByQueryVo(QueryVo queryVo);
}

public class QueryVo {

    private User user;

    private Integer[] ids;
}

<select id="findUserByQueryVo" parameterType="QueryVo" resultType="User">

     select * from mybatis.user where username like '%${user.username}%'

    </select>

resultMap

引入:
当数据库字段列名和pojo属性字段名映射不上;
但是又没有修改pojo的打算;或者修改表字段名的打算;
咋办呢?
用 resultMap 手动映射;

<!--

    查询结果用 包装的pojo 封装

    resultMap


    引入:
        当数据库字段列名和pojo属性字段名映射不上;
        但是又没有修改pojo的打算;或者修改表字段名的打算;
        咋办呢?
            用 resultMap 手动映射;

    -->


    <resultMap id="findById3ResultMap" type="User">
        <!--<id column="id" property="id"/>-->
        <result column="user_name" property="username"/>
        <result column="gender" property="sex"/>
        <!--<result column="birthday" property="birthday"/>-->
        <!--<result column="address" property="address"/>-->
    </resultMap>


    <select id="findById3" parameterType="int" resultMap="findById3ResultMap">
     select  * from  user_copy where id=#{id};
    </select>

动态sql:动态拼装sql

ognl语言: object graph navigation language

4165335-bcf8e73848df3376.png
ognl implementation.png

if

choose,when,otherwise

when,set

foreach

sql:复用sql语句

<sql>

引用
<include refid="sql_id" >

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 MyBatis 中,使用 @Param 注解可以向 SQL 映射文件传递参数。 如果在 mapper.java 中加了 @Param 注解,在 mapper.xml 中使用方法如下: ``` <select id="selectUser" resultType="User"> SELECT * FROM USER WHERE username = #{username} </select> ``` 可以替换为: ``` <select id="selectUser" resultType="User"> SELECT * FROM USER WHERE username = #{param1.username} </select> ``` 其中,"param1" 即为 @Param 注解的参数名称。 ### 回答2: 在Mapper.xml中,需要使用`<bind>`标签指定参数的取值,然后在SQL语句中使用取值的参数。 例如,在Mapper.java中,我们可以使用如下的注解来定义参数: ```java public List<User> getUsersByNameAndGender(@Param("name") String name, @Param("gender") String gender); ``` 在Mapper.xml中,我们需要使用`<bind>`标签给参数进行绑定,然后在SQL语句中使用被绑定的参数。 例如: ```xml <select id="getUsersByNameAndGender" resultType="User"> <bind name="name" value="@Param('name')" /> <bind name="gender" value="@Param('gender')" /> SELECT * FROM user WHERE name = #{name} AND gender = #{gender} </select> ``` 在上面的示例中,`<bind>`标签中的`name`属性指定了参数名称,`value`属性指定了参数的取值。然后在SQL语句中,我们可以使用这些被绑定的参数来构建查询条件。 这样,当在Java代码中调用这个方法时,传入的参数会被绑定到SQL语句中的相应位置,实现参数传递和动态SQL构建的功能。 ### 回答3: 在mapper.xml中,使用@Param注解将对应的参数传递到SQL语句中。具体写法如下: 1. 假设在mapper.java中的方法中使用了@Param注解,例如: ```java public List<User> getUserByAgeAndGender(@Param("age") int age, @Param("gender") String gender); ``` 2. 对应的mapper.xml中的SQL语句可以使用${}获取@Param注解中指定的参数名。例如: ```xml <select id="getUserByAgeAndGender" resultType="user"> SELECT * FROM users WHERE age = ${age} AND gender = #{gender} </select> ``` 这里使用${}获取@Param注解中的参数age,并使用#{gender}获取@Param注解中的参数gender。 需要注意的是,使用${}时会将参数直接替换到SQL语句中,可能存在SQL注入的风险。因此,如果参数是动态拼接SQL语句的一部分,建议使用#{}进行参数解析,如上例中的gender参数。 上述写法可以实现将mapper.java中的参数传递到mapper.xml中对应的SQL语句中。这样可以灵活地传递多个参数,并且提高代码的可读性和维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值