mybatis快速入门-注解版

发布于:2024-04-20 ⋅ 阅读:(26) ⋅ 点赞:(0)
  • mybatis 使用注解,简化 xml 配置,汲及到动态 sql 或是多表查询,还是使用 xml 映射文件配置编写。(企业工作中,几乎全是 xml 配置,xml 的 sql 使用注解方式少,而类引用注解方式)。

注解

  • @Select():查询
  • @Insert():添加
  • @Update():修改
  • @Delete():删除

mybatis.xml配置文件

<mappers>
       	<!-- 引入dao层接口所在文字,只需要到包的位置,不需要指定文件-->
        <package name="dao/mapper"/>
    </mappers>

查询

dao层接口

public interface BookModelDao {
    //Annotation
    //@Select():查询
    //@Insert():添加
    //@Update():修改
    //@Delete():删除
    //直接在抽象方法上注解约束,并写sql语句,调用抽象方法时,直接执行sql语句
    @Select("select * from book")
    List<BookModel>  findBookByAnnotation();
}

测试

//在main中调用
	findBookByAnnotation();
//方法
    public static void findBookByAnnotation() throws Exception{

        //引入mybatis.xml配置文件
        InputStream is = Resources.getResourceAsStream("mybatis.xml");
        //创建会话工厂
        SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(is);
        //创建sql会话
        SqlSession sqlSession = ssf.openSession();
        //获取dao层sql语句所在的类
        BookModelDao mapper = sqlSession.getMapper(BookModelDao.class);
        //调用抽象方法,执行sql语句,获取返回值
        List<BookModel> list = mapper.findBookByAnnotation();
        for (BookModel book : list){
            System.out.println(book);
        }
        sqlSession.close();
    }

添加

dao层接口

	//#{} 传入参数,名称可随意,与数据库字段名相同增加可读性
    @Insert("insert into book(name,price,num) values(#{name},#{price},#{num})")
    int insertBookByAnnotation(BookModel bookModel);

测试

//main中调用
	//创建实例
	BookModel bookModel = new BookModel("海底世界", 32, 1);
    insertBookByAnnotation(bookModel);

//方法
public static void insertBookByAnnotation(BookModel bookModel) throws Exception{
        /*
         //引入mybatis.xml配置文件
        InputStream is = Resources.getResourceAsStream("mybatis.xml");
        //创建会话工厂
        SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(is);
        //创建sql会话
        SqlSession sqlSession = ssf.openSession()
         */
        //JDBCUtil自定义封装方法:直接获取sql会话
        SqlSession sqlSession = JDBCUtil.getSqlSession();
        //接口绑定
        BookModelDao mapper = sqlSession.getMapper(BookModelDao.class);
        //调用添加方法,执行成功sql会返回执行的语句行数
        int row = mapper.insertBookByAnnotation(bookModel);
        //添加,删除,修改,都要commit,提交到数据库,查询可以省略
        //如果不提交,相当于执行在缓存池中,并不会更改数据库中的数据
        sqlSession.commit();
        System.out.println(row > 0 ? "添加成功" : "添加失败");
    }

mybatis快速入门基础篇
https://blog.csdn.net/weixin_44201223/article/details/137816871
mybatis快速入门进阶篇
https://blog.csdn.net/weixin_44201223/article/details/137865786
mybatis快速入门高级篇
https://blog.csdn.net/weixin_44201223/article/details/137912538