首页 > 其他分享 >MyBatis-使用注释方法执行操作案例-2023-04-18

MyBatis-使用注释方法执行操作案例-2023-04-18

时间:2023-04-18 10:44:50浏览次数:57  
标签:mapper 04 18 UserMapper sqlSession user 2023 import User

第一步:编写工具类,注意openSession 参数如增加true ,则为事务自动提交

package com.feijian.utils;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;

//sqlSessionFactory
public class MybatisUtils {
    private static SqlSessionFactory sqlSessionFactory;

    static{
        try {
            //第一步,获取sqlSessionFactory 对象
            String resource = "mybatis-config.xml";
            InputStream inputStream = Resources.getResourceAsStream(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            //sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    // 有了sqlSessionFactory ,可以获得sqlSession实例,如果在opensession中增加true,意味着事务自动提交
  public static SqlSession getSqlSession(){
      return sqlSessionFactory.openSession(true);
  }

}

第二步:编写核心配置文件 ,采用注释则注册的mapper 就是接口类了 class ,而不是resource

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<!--configuration 核心配置文件 -->
<configuration>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
<mappers>
    <mapper class="com.feijian.mapper.UserMapper"/>
</mappers>
</configuration>

第三步:编写接口类,并增加注解内容,实际上就是将之前UserMapper.xml的内容,写入到@Select @Update @Insert @Delete 等注释语句中

package com.feijian.mapper;

import com.feijian.pojo.User;
import org.apache.ibatis.annotations.*;

import java.util.List;
import java.util.Map;

public interface UserMapper {
    //获取全部用户
    @Select("select * from mybatis.user;")
    List<User> getUserList() ;

    //根据ID查询用户
    @Select("select * from mybatis.user where id = #{uid};")
    User getUserById(@Param("uid") int id);

    //insert一个新用户,影响的行数,所以返回boolean类型,true说明插入成功,一般不会反馈1表示插入成功!
    @Insert("insert into mybatis.user(id,name,pwd) values (#{id},#{name},#{pwd})")
    boolean addUser(User user);

    //修改用户 修改的行数
    @Update("update mybatis.user set name=#{name},pwd=#{pwd} where id=#{id};")
    boolean updateUser(User user);

    //删除用户
    @Delete("delete from mybatis.user where id = #{id};")
    boolean deleteUser(int id);
}

第四步:在核心配置文件中注册接口类 mapper  ---已注册,注意是class

<mappers>
    <mapper class="com.feijian.mapper.UserMapper"/>
</mappers>

第五步:调试, 一定要记住最后要关闭资源,close(), close(),close() 重要的事情强调三遍!!!

package com.feijian.mapper;

import com.feijian.pojo.User;
import com.feijian.utils.MybatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

import java.util.List;

public class UserMapperTest {
    //查询所有客户
    @Test
    public void test1(){
        //获得sqlsession
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //找到UserMapper类并生成mapper对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //调用接口类中的方法,查询所有用户
        List<User> userList = mapper.getUserList();
        //遍历打印输出
        for (User user : userList) {
            System.out.println(user);
        }
        //关闭资源
        sqlSession.close();
    }

    //根据ID查询
    @Test
    public void test2(){
        //获得sqlsession
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //找到UserMapper类并生成mapper对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //调用接口类中的方法,查询所有用户
        User user = mapper.getUserById(3);
        //遍历打印输出
        System.out.println(user);
        //关闭资源
        sqlSession.close();
    }

    //增加一个新用户
    @Test
    public void test3(){
        //获得sqlsession
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //找到UserMapper类并生成mapper对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //调用接口类中的方法,查询所有用户
        boolean flag =mapper.addUser(new User(6,"jun","230418"));
        //遍历打印输出
        System.out.println(flag);
        System.out.println("增加新用户成功!");
        //关闭资源
        sqlSession.close();
    }

    //修改一个用户
    @Test
    public void test4(){
        //获得sqlsession
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //找到UserMapper类并生成mapper对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //调用接口类中的方法,查询所有用户
        boolean flag =mapper.updateUser(new User(5,"liu","1234567"));
        //遍历打印输出
        System.out.println(flag);
        System.out.println("用户修改成功!");
        //关闭资源
        sqlSession.close();
    }

    //删除一个用户
    @Test
    public void test5(){
        //获得sqlsession
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //找到UserMapper类并生成mapper对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //调用接口类中的方法,查询所有用户
        boolean flag =mapper.deleteUser(9);
        //遍历打印输出
        System.out.println(flag);
        System.out.println("用户删除成功!");
        List<User> userList = mapper.getUserList();
        for (User user : userList) {
            System.out.println(user);
        }
        //关闭资源
        sqlSession.close();
    }
}

标签:mapper,04,18,UserMapper,sqlSession,user,2023,import,User
From: https://www.cnblogs.com/RUI2022/p/17328742.html

相关文章

  • DG搭建报错 ORA-16047: DGID mismatch between destination setting and target datab
    最近有需求要给数据库新搭一个DG变为一主两从,搭好之后测试发现一直没有同步,检查问题。从库一直等待接收71855号日志主库有归档日志发送失败的报错,可以看到归档到dest_2(原从库)是成功的,而到desc_3(新从库)则是失败的根据日志提示查看arc2进程的trace日志看到有ora-16058和ora-16047的报......
  • 【2023-04-17】爱情萌芽
    20:00胆小鬼连幸福都会惧怕,碰到棉花都会受伤,有时也会被幸福所伤。                                                 ——太宰治我最近爱上了一部爱情偶像连续剧,下班看......
  • 【2023-04-16】连岳摘抄
    23:59中国哲学儒、墨、道、法各家,传承数千年而蕴涵着中国文化的内涵,各有其普世的价值。这种普世价值,是指在人文精神的照耀下,老、孔、墨、庄的思想多散发出普世的情怀,即老子的贵柔及其宽容心态、孔子的恕道及其家庭伦理、墨子的兼爱与非攻思想、庄子的艺术人生和齐物精神。  ......
  • 产品原型14-20230417
             ......
  • 《白》 赋诗一首,2023.04.17
    白白色的冬天在我们的岁月中度过,欢快的笑脸在我们的冬天中度过,白白的雪花就是我欢快的来源,场场的大雪就是我们快乐的来源。 世界啊!哪一年没有冬?哪一个冬没有雪?哪一个雪中,没有我们欢乐的玩耍?......
  • 中电金信《2023商业银行大零售数字化转型白皮书》重磅发布
    4月13日,第六届零售银行发展大会在上海举办。中电金信基于对商业银行零售业务的理解和对行业的创新发展趋势研究,为银行零售业务的发展献计献策,在会上发布《商业银行大零售数字化转型白皮书》。白皮书总结了数字化转型的宏观环境、数字化时代商业银行零售业务主要特点、银行的转型困......
  • 2023-04-17 算法面试中常见的树和递归问题
    二叉树和递归0LeetCode297二叉树的序列化和反序列化序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据。请设计一个算法来实现二叉树的序列化与......
  • Hackers' Crackdown UVA11825
    你需要将n个集合分成尽量多组,使得每一组里面所有集合的并集等于全集  32122022014111013120   f[S]=max(f[S],f[S-j]+1)且j是一个包含所有点的集合#include<iostream>#include<algorithm>#include<cstring>usingname......
  • 2023/4/17笔记
    bind函数std::bind函数定义在头文件functional中,是一个函数模板,是函数适配器f - Callableobject(functionobject,pointertofunction,referencetofunction,pointertomemberfunction,orpointertodatamember)thatwillbeboundtosomearguments(参数).Cal......
  • 2023/4/17
    现在要开发一个系统,管理对多种汽车的收费工作。给出下面的一个基类框架classVehicle{protected:stringNO; public:Vehicle(stringn){NO=n;} virtualintfee()=0;//计算应收费用};以Vehicle为基类,构建出Car、Truck和Bus三个类。Car的收费公式为:载客......