8、mybatis-使用注解开发

本文介绍了如何在Mybatis中使用注解在接口上实现CRUD操作,包括@Select、@Insert、@Delete和@Update,以及如何通过动态代理和参数映射进行数据库交互,并演示了如何在测试中执行这些操作和设置自动提交事务。
摘要由CSDN通过智能技术生成

1、注解在接口上实现
@Select(“select * from user”)
List getUsers();
2、需要在核心配置文件上绑定接口

<mappers>
    <mapper class="cn.zhy.dao.UserMapper"/>
</mappers>

3、测试

@Test
public void Test01() {
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);

List<User> users = mapper.getUsers();
for (User user : users) {
    System.out.println(user);
}
sqlSession.close();
}

本质:反射机制的实现
底层:动态代理
使用注解进行增删查改
关于@Param
● //方法存在多个基本类型或String的参数,所有参数前面必须添加@Param(“id”)注解
● 引用数据类型不需要加
● 只有一个基本数据类型可以忽略,建议加上
● //注解取得参数对应的是@Param(“id”)中的
● 我们在SQL中#{}引用的就是我们这里的@Param()中设定的属性名!

可以在工具类中设置自动提交事务

//设置为true自动提交事物
public static SqlSession getSqlSession() {
return sqlSessionFactory.openSession(true);
}

新增

@Insert("insert into user (id, name, pwd) values (#{id}, #{name}, #{password})")
    int addUser(User user);
   @Test
    public void addUser() {
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        mapper.addUser(new User(1, "小王", "1111"));
        sqlSession.close();
    }

删除

@Delete("delete from user where id = #{id}")
    int deleteUser(int id);
  @Test
    public void deleteUser() {
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        mapper.deleteUser(7);
        sqlSession.close();
    }

更新

@Update("update user set name = #{name},pwd = #{password} where id = #{id}")
int updateUser(User user);
@Test
public void updateUser() {
    SqlSession sqlSession = MybatisUtils.getSqlSession();
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    mapper.updateUser(new User(1, "小王wang", "1111222"));
    sqlSession.close();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis-Plus支持注解形式的SQL开发。可以在Mapper接口的方法上使用注解来定义SQL语句。以下是一些常用的注解: 1. @Select: 用于查询语句,指定要执行的SQL语句。 2. @Insert: 用于插入语句,指定要执行的SQL语句。 3. @Update: 用于更新语句,指定要执行的SQL语句。 4. @Delete: 用于删除语句,指定要执行的SQL语句。 5. @Param: 用于指定参数的名称,可以在SQL语句中引用这些参数。 同时,Mybatis-Plus还支持使用@TableName注解来指定实体类与数据库表的映射关系,使用@TableField注解来指定实体类属性与数据库表字段的映射关系。 使用注解形式的SQL开发可以简化代码,提高开发效率。可以根据需要选择合适的注解来编写SQL语句,实现增删改查等操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [【SpringBoot】整合Mybatis-Plus并输出SQL日志](https://blog.csdn.net/friendlytkyj/article/details/130915860)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [springboot+shiro+mybatis-plus纯净版框架(附带所需数据库sql)](https://download.csdn.net/download/u011066516/12182453)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值