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

相关推荐
武昌库里写JAVA35 分钟前
39.剖析无处不在的数据结构
java·vue.js·spring boot·课程设计·宠物管理
Nelson_hehe3 小时前
Java基础第四章、面向对象
java·语法基础·面向对象程序设计
Thomas_YXQ3 小时前
Unity3D Lua集成技术指南
java·开发语言·驱动开发·junit·全文检索·lua·unity3d
ShiinaMashirol4 小时前
代码随想录打卡|Day27(合并区间、单调递增的数字、监控二叉树)
java·算法
东阳马生架构6 小时前
Nacos简介—3.Nacos的配置简介
java
北极的企鹅886 小时前
XML内容解析成实体类
xml·java·开发语言
oioihoii6 小时前
C++23 中 static_assert 和 if constexpr 的窄化布尔转换
java·jvm·c++23
聂 可 以6 小时前
调整IntelliJ IDEA当前文件所在目录(包路径)的显示位置
java·ide·intellij-idea
东阳马生架构6 小时前
Sentinel源码—7.参数限流和注解的实现一
java·sentinel
李白的粉6 小时前
基于springboot的在线教育系统
java·spring boot·毕业设计·课程设计·在线教育系统·源代码