目录
一、Mybatis详细执行流程
二、分页
1、使用limit分页
语法:select *from user limit ?,?
(1)接口定义方法
List<User> getUserByLimit(Map<String,Integer> map);
(2)编写配置文件
<select id="getUserByLimit" parameterType="map" resultMap="UserMap">
select * from mybatis.user limit #{startIndex},#{pageSize}
</select>
(3)测试
推断:起始位置
=
(当前页面
- 1
)
*
页面大小
@Test
public void getUserByLimittest(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
HashMap<String, Integer> map = new HashMap<String, Integer>();
map.put("startIndex",0);
map.put("pageSize",2);
List<User> limit = mapper.getUserByLimit(map);
for (User user :
limit) {
System.out.println(user);
}
sqlSession.close();
}
2、RowBounds实现分页(了解即可)
(1)接口定义方法
List<User> getUserByRowBounds();
(2)编写配置文件
<select id="getUserByRowBounds" resultType="user">
select * from user
</select>
(3)测试
@Test
public void getUserByLimittest(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
RowBounds rowBounds = new RowBounds(0,2);
List<User> users =
sqlSession.selectList("com.kuang.mapper.UserMapper.getUserByRowBounds", null, rowBounds);
for (User user :
users) {
System.out.println(user);
}
sqlSession.close();
}
3、PageHelper 分页插件(了解)
链接:https://pagehelper.github.io/
三、使用注解开发
注解也是运用映射的原理实现的,使用注解后就不再需要mapper.xml映射文件了
1、步骤
(1)在核心配置文件中注入
<mappers>
<mapper class="com.kuang.dao.UserDao"/>
</mappers>
(2)在接口中添加注解
@Select("select * from user")
List<User> getUsers();
(3)测试
@Test
public void test(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
List<User> users = mapper.getUsers();
for (User user : users) {
System.out.println(user);
}
sqlSession.close();
}
2、注解实现增删改查
(1)实现类编写注解
@Select("select * from user")
List<User> getUsers();
@Insert("insert into user(id,name,pwd) values(#{id},#{name},#{password})")
int addUser(User user);
@Update("update user set name=#{name},pwd=#{password} where id=#{id}")
int upDateUser(User user);
@Delete("delete from user where id=#{uid}")
int deleteUser(@Param("uid") int id);
(2)测试
注意:增删改需要提交事务
(可在配置文件中设置自动提交 sqlSessionFactory.openSession(true);)
List<User> users = mapper.getUsers();
for (User user : users) {
System.out.println(user);
}
int user = mapper.addUser(new User(4, "王五", "123123"));
mapper.upDateUser(new User(4,"赵六","000000"));
mapper.deleteUser(4);
(3)@Param
@Param注解用于给方法参数起一个名字。以下是总结的使用原则:
①在方法只接受一个参数的情况下,可以不使用@Param,建议使用以规范代码。
②在方法接受多个参数的情况下,建议一定要使用@Param注解给参数命名。
③如果参数是 JavaBean(即实体类) , 则不能使用@Param。
④不使用@Param注解时,参数只能有一个,并且是Javabean或基本类型。
⑤在sql中引用的就是在@Param中设置的属性名。
补充:
如果参数是JavaBean,则#{}中的内容一定要与实体类中的属性名一致,否则会报错。
如果参数是基本类型,#{}中的内容可随意取。
如果参数是Map,#{}中的内容为键名。