@TableName注解和@Table的区别及说明

目录
  • @TableName注解和@Table区别
    • 前言
    • @TableName参数说明
    • @Table
    • 小结一下
  • Table(name=“xx“)与Entity(name=“xx“) 问题

@TableName注解和@Table区别

最近开发项目的时候,从一个项目迁移代码到另一个项目,原有项目用的是Hibernate,现有项目用的是mybatis-plus,代码迁移过来后,schema属性用于指定数据库实例名。

但是@Table属性schema在mybatis-plus框架中失效了,一直找不到对应的实例名。

前言

@TableName是mybatis-plus中的注解,主要是实现实体类型和数据库中的表实现映射。

注意,不要将@TableName和@Table注解认为是一个,虽然功能相同,但是,@TableName是mybatis-plus中的注解,@Table是Hibernate中的注解。

@TableName参数说明

@TableName源码

public @interface TableName {
    java.lang.String value() default "";
    java.lang.String schema() default "";
    boolean keepGlobalPrefix() default false;
    java.lang.String resultMap() default "";
    boolean autoResultMap() default false;
}

@TableName使用

@TableName("sys_user")
// 该注解主要是现实实体类型和数据库中的表实现映射。
public class SysUser implements Serializable {
    @TableId(type= IdType.AUTO)
    private Long id;
    private String username;
    //用户名
    private String loginName;
    //登录密码,密码需要加密
    private String password;
}

@Table

当实体类与其映射的数据库表名不同名时需要使用 @Table 标注说明,该标注与 @Entity 标注并列使用,置于实体类声明语句之前,可写于单独语句行,也可与声明语句同行。

@Table 标注的常用选项是 name,用于指明数据库的表名

@Table标注还有一个两个选项 catalog 和 schema 用于设置表所属的数据库目录或模式,通常为数据库名。uniqueConstraints选项用于设置约束条件,通常不须设置。

  • name属性

name属性用于指定数据库表名称

若不指定则以实体类名称作为表名

  • catalog属性

catalog属性用于指定数据库实例名

当catalog属性不指定时,新创建的表将出现在url指定的数据库实例中

当catalog属性设置名称时,若数据库存在和指定名称一致的实例,新创建的表将出现在该实例中

  • schema属性

作用与catalog属性作用一致,可自行测试

  • uniqueConstraints属性

uniqueConstraints属性用于设定约束条件

@Table(name="CUSTOMERS",uniqueConstraints={@UniqueConstraint(columnNames={"name"})})
@Entity
public class Customer {
    private Integer id;
    private String name;
    private String email;
    private int age;
    ......
}

小结一下

1.当实体类名和数据库表名不一致时,name属性可以实现映射,及时表名一致,也推荐使用,提高程序的可读性

2.catalog和sechema属性一般不需要指定

3.uniqueConstraints属性一般也不需要指定,但是如有需要则可以指定

Table(name=“xx“)与Entity(name=“xx“) 问题

@Entity
@Table(name="T_qibie")

这样写的话在hql里要用实体的名字 from QibieVo

如果是这样的话

@Entity(name="T_qibie")

这样写的话在hql里要用表的名字 from T_qibie

还有有时候只能用@Entity(name="T_qibie")的话,可能是:JAVAEE6.0中的 javax.persistence.jar与 hibernate中的hibernate-jpa-2.1-api-1.0.0.Final.jar冲突 ,而我采取的措施是删除了JAVAEE6.0的库,运行就正常了,然后在加进来有正常了 。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • MybatisPlus中@TableField注解的使用详解

    实现 官方文档说明: com.baomidou.mybatisplus.annotations.TableField TableField注解新增属性 update 预处理 set 字段自定义注入 (讲解:比如我们使用mybatisplus自带的insert()方法向数据库插入数据时,假设我们给age字段赋值为1,但是我们在age字段上的@TableField注解里面加了update="%s+1",那么真真插入到数据库的值就是age=2,而不是age+1了) 例如: @TableFie

  • 关于MyBatis通用Mapper@Table注解使用的注意点

    目录 MyBatis通用Mapper@Table注解使用 @Table注解的作用 通用mapper使用需要注意的问题 首先是实体需要有相关的注解 其次需要注意点事 具体使用的依赖 MyBatis通用Mapper@Table注解使用 @Table注解的作用 一般作用在pojo实体类的类名上,使用该注解后pojo类的属性会和对应的表字段做一个映射关系(和<resultMap>标签有着异曲同工之处),对于简单的映射关系来说可以不用再xml文件里写<resultMap>标签作映射了. 那么

  • mybatis自动生成@Table、@Column、@Id注解的方法

    在pom.xml中添加如下插件以及插件相关的依赖 <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <configuration> <!--配置文件的位置--> <configurat

  • @TableName注解和@Table的区别及说明

    目录 @TableName注解和@Table区别 前言 @TableName参数说明 @Table 小结一下 Table(name=“xx“)与Entity(name=“xx“) 问题 @TableName注解和@Table区别 最近开发项目的时候,从一个项目迁移代码到另一个项目,原有项目用的是Hibernate,现有项目用的是mybatis-plus,代码迁移过来后,schema属性用于指定数据库实例名. 但是@Table属性schema在mybatis-plus框架中失效了,一直找不到对应的

  • Java如何获取@TableField,@TableName注解的值

    目录 如何获取@TableField,@TableName注解的值 操作方式 小结一下 @TableName和@TableId爆红 加入pom依赖 如何获取@TableField,@TableName注解的值 总觉得写博客要形成自己的风格才行,不能像记流水账一样记录,比如文章有开头,过程,结尾,总结.虽说文章的好坏,跟排版无关,但是至少看得人看的舒服.所以说,要有自己的风格.比如,文章是为了记录什么,解决什么,学到了什么,总结之后给别人帮助.这才是挺有意思的一件事. 不多说,上菜. 有这么一个需

  • @Bean注解和@Configuration、@Component注解组合使用的区别

    目录 一.@Bean的"full"模式和"lite"模式 二.两种模式的差异 1."full"模式下@Bean方法互相调用 2."lite"模式下@Bean方法互相调用 三.总结 一.@Bean的"full"模式和"lite"模式 在一般常见情况下,@Bean注解在@Configuration类中声明,称之为"full"模式:当@Bean注解和@Component注解

  • spring的Cache注解和redis的区别说明

    目录 spring Cache注解和redis区别 1.不支持TTL 2.内部调用 3.key的问题 Spring Cache注解+redis整合及遇到的坑 先介绍Spring Cache注解 配置Spring注解与Redis整合 我们在Spring-config.xml中来配置 来写RedisCache这个类,让其实现Cache接口 开始使用注解,我是把其作用在倒dao层中 运行结果 key的生成策略 spring Cache注解和redis区别 1.不支持TTL 即不能设置过期时间 expi

  • @Valid注解的作用及@Valid注解与@Validated的区别

    目录 1.@Valid注解 2.@Valid与@Validated的区别 注解位置 分组校验 组序列 嵌套校验 1.@Valid注解 用于验证注解是否符合要求,直接加在变量user之前,在变量中添加验证信息的要求,当不符合要求时就会在方法中返回message 的错误提示信息. @ApiOperation(value = "Shipping receive completion request from shiphub frontend or app client like OMS",

  • Spring注解@Resource和@Autowired区别对比详解

    前言 @Resource和@Autowired都是做bean的注入时使用,其实@Resource并不是Spring的注解,它的包是javax.annotation.Resource,需要导入,但是Spring支持该注解的注入. 1.共同点 两者都可以写在字段和setter方法上.两者如果都写在字段上,那么就不需要再写setter方法. 2.不同点 (1)@Autowired @Autowired为Spring提供的注解,需要导入包org.springframework.beans.factory

  • 关于@Entity和@Table注解的用法详解

    目录 @Entity和@Table注解的用法 @Entity注解 @Table注解 @Entity和@Table的区别 @Entity和@Table注解的用法 @Entity注解 @Entity注解和@Table注解都是Java Persistence API中定义的一种注解. @Entity说明这个class是实体类,并且使用默认的orm规则,即class名就是数据库表中表明,class字段名即表中字段名.@Entity注解指明这是一个实体Bean. import lombok.Data; 

  • 通过反射注解批量插入数据到DB的实现方法

    批量导入思路 最近遇到一个需要批量导入数据问题.后来考虑运用反射做成一个工具类,思路是首先定义注解接口,在bean类上加注解,运行时通过反射获取传入Bean的注解,自动生成需要插入DB的SQL,根据设置的参数值批量提交.不需要写具体的SQL,也没有DAO的实现,这样一来批量导入的实现就和具体的数据库表彻底解耦.实际批量执行的SQL如下: insert into company_candidate(company_id,user_id,card_id,facebook_id,type,create

  • mysql清空表数据的两种方式和区别解析

    在MySQL中删除数据有两种方式: truncate(截短)属于粗暴型的清空 delete属于精细化的删除 删除操作 如果你需要清空表里的所有数据,下面两种均可: delete from tablename; truncate table tablename; 而如果你只是删除一部分数据,就只能使用delete: delete from tablename where case1 and case2; 区别 在精细化的删除部分数据时,只能使用delete. 而清空所有表数据时,两者均可,此时这两

随机推荐