MyBatis:配置文件Mapper.xml

一、Mapper.xml 的作用?

MyBatis 框架是一个“半自动”的 ORM 框架,SQL 语句需要开发者自定义,MyBatis 框架的关注点在于 Java Bean 于 SQL 之间的映射关系,自定义的 SQL 语句定义在 Mapper.xml 中。

二、Mapper.xml 常用属性

1、parameterType 参数数据类型

  • (1) 基本数据类型

通过 id 查询 User。

UserRepository

//通过 id 查询 User
public User findById(int id);

UserRepository.xml

<select id="findById" parameterType="int" resultType="com.spring.entity.User">
	select * from t_user where id = #{id}
</select>
  • (2) String 类型

通过 username 查询 User。

UserRepository

//通过 username 查询 User
public User findByUsername(String username);

UserRepository.xml

<select id="findByUsername" parameterType="java.lang.String" resultType="com.spring.entity.User">
    select * from t_user where username = #{username}
</select>
  • (3) 包装类

通过 age 查询 User。

UserRepository

//通过 age 查询 User
public User findByAge(Integer age);

UserRepository.xml

<select id="findByAge" parameterType="java.lang.Integer" resultType="com.spring.entity.User">
    select * from t_user where age = #{age}
</select>
  • (4) 多个参数

通过 username 和 age 查询 User。两个参数分别是 String 类型和 int 类型,类型不一致,所以此时 parameterType 可以省略,通过参数下标取出参数值。

UserRepository

//通过username和age查询User
public User findByUsernameAndAge(String username,int age);

UserRepository.xml

<select id="findByUsernameAndAge" resultType="com.spring.entity.User">
    select * from t_user where username = #{param1} and age = #{param2}
</select>
  • (5) JavaBean

当同时存在多个参数时,通过下标一个一个写很麻烦,这时候可以将参数列表进行封装,将封装的对象作为 paramterType 的值。

UserRepository

//通过User封装对象查询User
public User findByUser(User user);

UserRepository.xml

<select id="findByUser" parameterType="com.spring.entity.User" resultType="com.spring.entity.User">
    select * from t_user where username = #{username} and age = #{age}
</select>

2、resultType:结果类型

  • (1) 基本数据类型

统计 User 总数。

UserRepository

//统计User总数
public int count();

UserRepository.xml

<select id="count" resultType="int">
	select count(*) from user
</select>
  • (2) 包装类

统计 User 总数。

UserRepository

//统计User总数
public Integer count();

UserRepository.xml

<select id="count" resultType="java.lang.Integer">
    select count(*) from t_user
</select>
  • (3) String类型

根据 id 查询 User 的 username。

UserRepository

//根据 id 查询 User 的 username
public String findNameById(int id);

UserRepository.xml

<select id="count" resultType="int">
	select count(*) from user
</select>
  • (4) JavaBean

通过 id 查询 User

UserRepository

//根据 id 查询 User
pulbic User findById(int id);

UserRepository.xml

<select id="findById" parameterType="int" resultType="com.spring.entity.User">
	select * from t_user where id = #{id}
</select>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值