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

相关推荐
严文文-Chris10 分钟前
【设计模式-享元】
android·java·设计模式
Flying_Fish_roe26 分钟前
浏览器的内存回收机制&监控内存泄漏
java·前端·ecmascript·es6
c#上位机36 分钟前
C#事件的用法
java·javascript·c#
【D'accumulation】1 小时前
典型的MVC设计模式:使用JSP和JavaBean相结合的方式来动态生成网页内容典型的MVC设计模式
java·设计模式·mvc
试行1 小时前
Android实现自定义下拉列表绑定数据
android·java
茜茜西西CeCe2 小时前
移动技术开发:简单计算器界面
java·gitee·安卓·android-studio·移动技术开发·原生安卓开发
救救孩子把2 小时前
Java基础之IO流
java·开发语言
小菜yh2 小时前
关于Redis
java·数据库·spring boot·redis·spring·缓存
ggdpzhk2 小时前
Mybatis 快速入门(maven)
oracle·maven·mybatis
宇卿.2 小时前
Java键盘输入语句
java·开发语言