mybatis快速入门-注解版

  • mybatis 使用注解,简化 xml 配置,汲及到动态 sql 或是多表查询,还是使用 xml 映射文件配置编写。(企业工作中,几乎全是 xml 配置,xml 的 sql 使用注解方式少,而类引用注解方式)。

注解

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

mybatis.xml配置文件

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

查询

dao层接口

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

测试

java 复制代码
//在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层接口

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

测试

java 复制代码
//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

相关推荐
在等晚安么11 分钟前
力扣面试经典150题打卡
java·数据结构·算法·leetcode·面试·贪心算法
Fency咖啡17 分钟前
Spring进阶 - Spring事务理论+实战,一文吃透事务
java·数据库·spring
Zxxxxxy_39 分钟前
【MYSQL】增删改查
java·数据库·mysql
菜鸟的迷茫39 分钟前
线程池中的坑:线程数配置不当导致任务堆积与拒绝策略失效
java·后端
缺点内向41 分钟前
Java 使用 Spire.XLS 库合并 Excel 文件实践
java·开发语言·excel
asdfsdgss42 分钟前
多项目共享资源:Ruby 定时任务基于 Whenever 的动态扩缩容
java·网络·ruby
Deamon Tree1 小时前
Redis的过期策略以及内存淘汰机制
java·数据库·redis·缓存
Jing_jing_X1 小时前
Java 多线程:从单体到分布式的演进与陷阱
java·分布式
fouryears_234171 小时前
Redis缓存更新策略
java·spring boot·redis·spring
百锦再1 小时前
Go与Python在AI大模型开发中的深度对比分析
java·开发语言·人工智能·python·学习·golang·maven