zoukankan      html  css  js  c++  java
  • Mybatis常见注解有哪些?这篇总结全面了

    当下,注解非常流行,以前很长篇的代码,现在基本上一个注解就能搞定。

    那,在Mybatis中又有哪些注解呢?

    Mybatis中的注解基本上都在org.apache.ibatis.annotations目录下:

    @MapperScan
    该注解存在着争议,但不可否认的是这个注解确实是Mybatis的注解,是为了集成Spring而写的注解。该注解主要是扫描某个包目录下的Mapper,将Mapper接口类交给Spring进行管理。

    org.mybatis.spring.annotation.MapperScan
    使用方式
    @SpringBootApplication
    @MapperScan("com.tian.mybatis.mapper")
    public class Application {
    }
    其实,从名字上就能看出,是用来扫描的Mapper的。

    扫描包路径可以是一个或者多个,也可以在路径中可以使用 * 作为通配符对包名进行匹配 。

    @SpringBootApplication
    @MapperScan("com.tian.*.mapper")
    public class Application {
    }
    @SpringBootApplication
    @MapperScan({"com.tian.mybatis.mapper","com.tian.mybatis.mapper1"})
    public class Application {
    }
    灵活度相当高,这样在实际上项目中,我们就可以指定扫描想要被扫描的包路径。

    @Mapper
    该注解目的就是为了不再写mapper映射文件 (UserMapper.xml)。可以大大的简化编写xml的繁琐。该注解是由Mybatis框架中定义的一个描述数据层接口的注解,注解往往起到的都是一个描述性作用,用于告诉Spring框架此接口的实现类由Mybatis负责创建,并将其实现类对象存储到spring容器中。

    使用方式
    @Mapper
    public interface UserMapper {
    User selectById(Integer id);
    }
    @Insert
    插入记录的时候主键如何生成?对此基本上有三种方案,分别是:手动指定(应用层)、自增主键(数据层单表)、选择主键(数据层多表)。

    对应xml文件中的标签。

    在应用层手动指定主键
    手动指定的方式不把主键区别看待,插入之前在应用层生成对象的时候就会给主键一个值,插入的时候与普通字段没啥区别。

    /**

    • 插入记录,手动分配主键
      */
      @Insert("INSERT INTO t_user (id, username, passwd) VALUES (#{id}, #{username}, #{passwd})")
      int addUserAssignKey(User user);
      在上面的这个例子中,mybatis并不知道到底哪个字段是主键,id虽然是主键字段,但并没有被区别对待。

    「注意」

    {username}这种写法,是把User作为了当前上下文,这样访问User的属性的时候直接写属性名字就可以了。

    表自增主键
    自增主键对应着XML配置中的主键回填,一个简单的例子:

    /**

    • 插入记录,数据库生成主键
      */
      @Options(useGeneratedKeys = true, keyProperty = "id")
      @Insert("INSERT INTO t_user (username, passwd) VALUES (#{username}, #{passwd})")
      int addUserGeneratedKey(User user);
      使用Option来对应着XML设置的select标签的属性,userGeneratordKeys表示要使用自增主键,keyProperty用来指定主键字段的字段名。自增主键会使用数据库底层的自增特性。

    选择主键
    选择主键从数据层生成一个值,并用这个值作为主键的值。

    /**

    • 插入记录,选择主键
      */
      @Insert("INSERT INTO t_user (username, passwd) VALUES (#{username}, #{passwd})")
      @SelectKey(statement = "SELECT UNIX_TIMESTAMP(NOW())", keyColumn = "id", keyProperty = "id", resultType = Long.class, before = true)
      int addUserSelectKey(User user);
      @Delete
      删除的时候只要把语句条件神马的写在@Delete注解的value里就好了,返回一个int类型是被成功删除的记录数。对应xml文件中的标签。

    /**

    • 删除记录
      */
      @Delete("DELETE FROM t_user WHERE id=#{id}")
      int delete(Long id);
      @Update
      修改的时候和删除一样只要把SQL语句写在@Update的value中就好了,返回一个int类型表示被修改的记录行数。

    对应xml文件中的标签。

    /**

    • 修改记录
      */
      @Update("UPDATE t_user SET username=#{username}, passwd=#{passwd} WHERE id=#{id}")
      int update(User user);
      @Select
      查询的时候稍稍有些复杂,因为查询会涉及到如何将查出来的字段设置到对象上,对应xml文件中的
  • 相关阅读:
    P2805 [NOI2009]植物大战僵尸
    P3833 [SHOI2012]魔法树
    LOJ121 「离线可过」动态图连通性
    POJ2774 Long Long Message
    POJ2406 Power Strings
    SPOJ 694 DISUBSTR
    POJ3261 Milk Patterns
    HIHOcoder 1466 后缀自动机六·重复旋律9
    P2504 [HAOI2006]聪明的猴子
    P3804 【模板】后缀自动机
  • 原文地址:https://www.cnblogs.com/tianweichang/p/14172390.html
Copyright © 2011-2022 走看看