MyBatis基础入门-4

MyBatis-4

成员代码块

构造代码块:

直接在类中定义且没有加static关键字的代码块称为{}构造代码块。构造代码块在创建对象时被调用,每次创建对象都会被调用,并且构造代码块的执行次序优先于类构造函数。

//eg:
 new SQL(){
            
            
            {
                SELECT("*");
                FROM("student");
                
            } // 成员代码块儿, 构造代码块儿
            
 };

静态代码块:

在java中使用static关键字声明的代码块。静态块用于初始化类,为类的属性初始化。每个静态代码块只会执行一次。由于JVM在加载类时会执行静态代码块,所以静态代码块先于主方法执行。

如果类中包含多个静态代码块,那么将按照"先定义的代码先执行,后定义的代码后执行"。

注意:

1 、静态代码块不能存在于任何方法体内。

2 、静态代码块不能直接访问静态实例变量和实例方法,需要通过类的实例对象来访问。

SQL构建器

 @SelectProvider(type = ReturnSql.class , method = "getSelectAll")
  • @SelectProvider
    • type:指定提供sql的功能类
    • method:指定调用功能类的哪一个方法

sql构建器使用步骤

  1. 构建sql构建类
  2. 编写—方法,返回值为String
  3. 在原本注解开发的地方将原有的@XXX注解改为@XXProvider注解
    1. type参数指定构建类
    2. method指定对应sql的方法

MyBatis整合工程

  1. 导包,mybaitis+mysql

    • 将mybatis的jar拷贝到WEB-INF/lib
  2. 拷贝核心配置文件(log4j.properties、MyBatisConfig.xml)

    • 到src目录下面
    • 修改加载的配置文件(jdbc.properties修改为config.properties)
    • 确认映射配置文件加载是否正确(Mappers标签)
  3. 接口文件(添加对应注解)

    1. 给接口文件添加对应sql

       //查询所有学生信息
       @Select("SELECT * FROM student")
      
      //条件查询,根据id获取学生信息
         @Select("SELECT * FROM student WHERE sid=#{sid}")
      
      //新增学生信息
      @Insert("INSERT INTO student VALUES (#{sid},#{name},#{age},#{birthday})")
      
      //修改学生信息
       @Delete("DELETE FROM student WHERE sid=#{sid}")
      
      
  4. service层调用dao层的接口代理实现

    1. 加载配置文件获取SQLSession
    2. 拿到Mapper代理实现类调用对应方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值