1.我们可以在工具类创建的时候实现自动提交事务!
public static SqlSession getSqlSession(){
return sqlSessionFactory.openSession (true);
}
2.编写接口,增加注解
public interface UserMapper {
//获取全部的用户
@Select ("select * from user")
List<User> getUsers();
//方法存在多个参数,所有的参数前面必须加上@Param ("id")注解
@Select ("select * from user where id = #{id} ")
User getUserbyid(@Param ("id") int id);
@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 ("delte from user where id = #{uid}")
int delectUser(@Param ("uid") int id);
}
3.测试类
【注意:我们必须要讲接口注册绑定到我们的核心配置文件中!】
public class UserMapperTest {
@Test
public void getUserstest(){
SqlSession sqlSession = MybatisUtils.getSqlSession ();
//获取Session
//底层主要应用反射
UserMapper mapper =sqlSession.getMapper (UserMapper.class);
mapper.delectUser (5);
mapper.adduser (new User (5,"Hello","1234567"));
List<User> users = mapper.getUsers ();
for (User user : users) {
System.out.println (user);
}
//关闭
User userid = mapper.getUserbyid (1);
System.out.println (userid);
sqlSession.close ();
}
}
关于@Param()注解
1.基本类型的参数或者String类型,需要加上
2.引用类型不需要加
3.如果只有一个基本类型的话,可以忽略,但是建议大家都加上!、
我们在SLQ中引用的就是我们@Param("id")中设定的属性名!