在开发中向spring等一般是使用注解开发,mybatis使用xml的多一些。
1、我们在我们的接口中添加注解
//查询全部用户
@Select(“select id,name,pwd password from user”)
public List getAllUser();
2、在mybatis的核心配置文件中注入
3、我们去进行测试
【注意】确保实体类和数据库字段对应
@Test
public void testGetAllUser() {
SqlSession session = MybatisUtils.getSession();
//本质上利用了jvm的动态代理机制
UserMapper mapper = session.getMapper(UserMapper.class);
List users = mapper.getAllUser();
for (User user : users){
System.out.println(user);
}
session.close();
}
使用注解来映射简单语句会使代码显得更加简洁,但对于稍微复杂一点的语句,Java 注解不仅力不从心,还会让你本就复杂的 SQL 语句更加混乱不堪。 因此,如果你需要做一些很复杂的操作,最好用 XML 来映射语句。
CRUD
我们可以在工具类创建的时候实现自动提交事务
public static SqlSession getSqlSession(){
return sqlSessionFactory.openSession(true);//设置自动提交
}
编写接口,增加注解
//添加一个用户
@Insert("insert into user (id,name,pwd) values (#{id},#{name},#{pwd})")
int addUser(User user);
//修改一个用户
@Update("update user set name=#{name},pwd=#{pwd} where id = #{id}")
int updateUser(User user);
//根据id删除用
@Delete("delete from user where id = #{id}")
int deleteUser(@Param("id")int id);
在mybatis核心配置文件中绑定
<!--绑定接口-->
<mappers>
<mapper class="ustc.gzy.dao.UserMapper"/>
</mappers>
测试类
关于@Param
@Param注解用于给方法参数起一个名字。以下是总结的使用原则:
- 在方法只接受一个参数的情况下,可以不使用@Param。
- 在方法接受多个参数的情况下,建议一定要使用@Param注解给参数命名。
- 如果参数是 JavaBean , 则不能使用@Param。
- 不使用@Param注解时,参数只能有一个,并且是Javabean。
- 基本类型 的参数或者String类型都需要加上
- 引用类型不需要加
- 我们在sql 中引用的就是我们这里的@Param("")中设定的属性名
#与$的区别
#方式sql注入