04day遇见狂神说--MyBatis--使用注解开发@param,@Select,@update等

在开发中向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注入

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值