转载

【@Transient】 @Transient的使用方法

温馨提示:
本文最后更新于 2018年11月20日,已超过 2,187 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我

@Transient的作用是指定该属性或字段不是永久的。 它用于注释实体类,映射超类或可嵌入类的属性或字段。

它既可以写在属性的上面,也可以写在属性get方法的上面。
在实际的使用过程中,如果属性没有get方法。下面这种写法是没有问题的。数据库表中不会有test字段。

 @Transient
    private String test;

如果有get方法,就要把@Transient注解写到get方法上面,下面这种写法也是没有问题的。

  private String test;

    @Transient
    public String getTest() {
        return test;
    }

    public void setTest(String test) {
        this.test = test;
    }

但是如果test属性有get方法,你又把@Transient写在了属性上面,数据库表中就会新增一个字段。

 @Transient
    private String test;

    public String getTest() {
        return test;
    }

    public void setTest(String test) {
        this.test = test;
    }

下面来看以类作为属性的@Transient使用。

 @Transient
    private MemberConfig memberConfig;

上面这种情况是不会有问题的,既不会报错也不会产生相应字段,但是怎么写图什么呢?一般来说用@Transient是希望该属性不会在数据表中产生字段,但又可以在程序中使用它。于是,我们决定这么写。

 @Transient
    private MemberConfig memberConfig;

    public MemberConfig getMemberConfig() {
        MemberConfig memberConfig = new MemberConfig(getAttr());
        return memberConfig;
    }

    public void setMemberConfig(MemberConfig memberConfig) {
        this.getAttr().putAll(memberConfig.getAttr());
    }

我们希望可以用getMemberConfig()来获取一个MemberConfig实例(getAttr()是用来给MemberConfig对象赋值),结果报错了。错误代码:

Caused by: org.hibernate.MappingException: Could not determine type for: com.zttech.demo.cms.entity.MemberConfig, at table: t_cms_config, for columns: [org.hibernate.mapping.Column(memberConfig)]
    at org.hibernate.mapping.SimpleValue.getType(SimpleValue.java:336)
    at org.hibernate.mapping.SimpleValue.isValid(SimpleValue.java:310)
    at org.hibernate.mapping.Property.isValid(Property.java:241)
    at org.hibernate.mapping.PersistentClass.validate(PersistentClass.java:496)
    at org.hibernate.mapping.RootClass.validate(RootClass.java:270)
    at org.hibernate.cfg.Configuration.validate(Configuration.java:1360)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1851)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1930)
    at org.springframework.orm.hibernate4.LocalSessionFactoryBuilder.buildSessionFactory(LocalSessionFactoryBuilder.java:372)
    at org.springframework.orm.hibernate4.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java:454)
    at org.springframework.orm.hibernate4.LocalSessionFactoryBean.afterPropertiesSet(LocalSessionFactoryBean.java:439)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1637)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1574)
    ... 81 more

这个错误大概意思就是在生成字段的时候无法确定MemberConfig的类型。因为从之前的实验中我们可以看到当一个属性有get方法是,如果不把@Transient注解写到get方法上,hibernate依然会在数据表中新建一个字段。所以才会出现这样的错误。
所以用下面的写法才是正确的:

 private MemberConfig memberConfig;

    @Transient
    public MemberConfig getMemberConfig() {
        MemberConfig memberConfig = new MemberConfig(getAttr());
        return memberConfig;
    }

    public void setMemberConfig(MemberConfig memberConfig) {
        this.getAttr().putAll(memberConfig.getAttr());
    }

既不会报错,也不会生成字段,还能正常使用MemberConfig。当然private MemberConfig memberConfig;其实是没有用的,不写也可以

正文到此结束
本文目录