JPA 和 Hibernate 与 MySQL 的映射:字段“描述”;没有默认值

发布于 2024-12-19 11:28:57 字数 12003 浏览 0 评论 0原文

当我尝试在数据库中插入值时出现以下异常。 这是我的持久性类:

<pre> 
@SuppressWarnings("serial")
@Entity
@Table(name = "consumer", catalog = "oauth")
@NamedQueries({
    @NamedQuery(name = Consumer.QUERY_BY_CONSUMER_KEY, query = "SELECT i FROM " + Consumer.TABLENAME + " i WHERE i.consumerKey = :" + Consumer.Q_PARAM_CONSUMER_KEY)})
public class Consumer implements java.io.Serializable {

    public static final String TABLENAME = "Consumer";
    public static final String QUERY_BY_CONSUMER_KEY = "ConsumerFindByConsumerKey";
    public static final String Q_PARAM_CONSUMER_KEY = "consumer_key";
    @Id
    @GeneratedValue(strategy = IDENTITY)
    @Column(name = "id", unique = true, nullable = false)
    private Integer id;
    @ManyToOne
    @JoinColumn(name = "user_id", nullable = false)
    private Idpuser idpuser;
    @Column(name = "description", nullable = false, length = 500)
    private String description;
    @Column(name = "consumer_key", nullable = false, length = 100)
    private String consumerKey;
    @Column(name = "consumer_secret", nullable = false, length = 100)
    private String consumerSecret;
    @Column(name = "callbackurl", nullable = false, length = 400)
    private String callbackURL;
    @Column(name = "request_token", length = 500)
    private String requestToken;
    @Column(name = "token_secret", length = 500)
    private String tokenSecret;
    @Column(name = "access_token", length = 500)
    private String accessToken;
    @Temporal(TemporalType.TIMESTAMP)
    @Column(name = "acces_token_valid_from", length = 19)
    private Date accesTokenValidFrom;
    @Temporal(TemporalType.TIMESTAMP)
    @Column(name = "access_token_valid_to", length = 19)
    private Date accessTokenValidTo;
    @Column(name = "access_token_num_usage_count")
    private Integer accessTokenNumUsageCount;
    @Column(name = "access_token_max_usage_count")
    private Integer accessTokenMaxUsageCount;
    @Column(name = "authorized", nullable = false)
    private Boolean authorized;
    @ManyToMany(fetch= FetchType.EAGER)
    @JoinTable(name = "consumer_role_relation",
    joinColumns = { 
      @JoinColumn(name = "consumer_id")
    }, 
    inverseJoinColumns = {
      @JoinColumn(name = "role_id")
    }
    )
    private Set<Role> roles = new HashSet<Role>(0);

    @Column(name = "facebookId", unique = true)
    private BigInteger facebookId;


    protected Consumer() {
    }

    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
    }

    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized,
            Date accesTokenValidFrom, Date accessTokenValidTo, int accessTokenMaxUsageCount) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
        this.accesTokenValidFrom = accesTokenValidFrom;
        this.accessTokenValidTo = accessTokenValidTo;
        this.accessTokenMaxUsageCount = accessTokenMaxUsageCount;
    }

    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized,
            Date accesTokenValidFrom, Date accessTokenValidTo, int accessTokenMaxUsageCount, Set<Role> roles) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
        this.accesTokenValidFrom = accesTokenValidFrom;
        this.accessTokenValidTo = accessTokenValidTo;
        this.accessTokenMaxUsageCount = accessTokenMaxUsageCount;
        this.roles = roles;
    }

    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized,
            Date accesTokenValidFrom, Date accessTokenValidTo) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
        this.accesTokenValidFrom = accesTokenValidFrom;
    }


    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized,
            Date accesTokenValidFrom, Date accessTokenValidTo, Set<Role> roles) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
        this.accesTokenValidFrom = accesTokenValidFrom;
        this.roles = roles;
    }


    public Integer getId() {
        return this.id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public Idpuser getIdpuser() {
        return this.idpuser;
    }

    public void setIdpuser(Idpuser idpuser) {
        this.idpuser = idpuser;
    }

    public String getDescription() {
        return this.description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    public String getConsumerKey() {
        return this.consumerKey;
    }

    public void setConsumerKey(String consumerKey) {
        this.consumerKey = consumerKey;
    }

    public String getConsumerSecret() {
        return this.consumerSecret;
    }

    public void setConsumerSecret(String consumerSecret) {
        this.consumerSecret = consumerSecret;
    }

    public String getCallbackURL() {
        return callbackURL;
    }

    public void setCallbackURL(String callbackURL) {
        this.callbackURL = callbackURL;
    }

    public Date getAccesTokenValidFrom() {
        return accesTokenValidFrom;
    }

    public void setAccesTokenValidFrom(Date accesTokenValidFrom) {
        this.accesTokenValidFrom = accesTokenValidFrom;
    }

    public String getAccessToken() {
        return accessToken;
    }

    public void setAccessToken(String accessToken) {
        this.accessToken = accessToken;
    }

    public Integer getAccessTokenMaxUsageCount() {
        return accessTokenMaxUsageCount;
    }

    public void setAccessTokenMaxUsageCount(Integer accessTokenMaxUsageCount) {
        this.accessTokenMaxUsageCount = accessTokenMaxUsageCount;
    }

    public Integer getAccessTokenNumUsageCount() {
        return accessTokenNumUsageCount;
    }

    public void setAccessTokenNumUsageCount(Integer accessTokenNumUsageCount) {
        this.accessTokenNumUsageCount = accessTokenNumUsageCount;
    }

    public Date getAccessTokenValidTo() {
        return accessTokenValidTo;
    }

    public void setAccessTokenValidTo(Date accessTokenValidTo) {
        this.accessTokenValidTo = accessTokenValidTo;
    }

    public Boolean getAuthorized() {
        return authorized;
    }

    public void setAuthorized(Boolean authorized) {
        this.authorized = authorized;
    }

    public String getRequestToken() {
        return requestToken;
    }

    public void setRequestToken(String requestToken) {
        this.requestToken = requestToken;
    }

    public String getTokenSecret() {
        return tokenSecret;
    }

    public void setTokenSecret(String tokenSecret) {
        this.tokenSecret = tokenSecret;
    }  

    public Set<Role> getRoles(){
        return this.roles;
    }

    public void setRoles(Set<Role> roles){
        this.roles = roles;
    }

    public void addRole(Role r){
        this.roles.add(r);
    }

    public void removeRole(Role r){
        this.roles.remove(r);
    }

    @Override
    public String toString(){
        return this.description;
    }



    /* (non-Javadoc)
     * @see java.lang.Object#hashCode()
     */
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result
                + ((consumerSecret == null) ? 0 : consumerSecret.hashCode());
        return result;
    }

    /* (non-Javadoc)
     * @see java.lang.Object#equals(java.lang.Object)
     */
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        Consumer other = (Consumer) obj;
        if (consumerSecret == null) {
            if (other.consumerSecret != null)
                return false;
        } else if (!consumerSecret.equals(other.consumerSecret))
            return false;
        return true;
    }



    /* ###### Listener handling ###########################  */
    @Transient
    private CopyOnWriteArrayList<Object> listeners = new CopyOnWriteArrayList<Object>();

    public CopyOnWriteArrayList<Object> getListeners() {
        return listeners;
    }

    public void setListeners(CopyOnWriteArrayList<Object> listeners) {
        this.listeners = listeners;
    }

    public BigInteger getFacebookId() {
        return facebookId;
    }

    public void setFacebookId(BigInteger facebookId) {
        this.facebookId = facebookId;
    }    
}

</pre>

异常:

<pre>
Dez 03, 2011 12:58:21 PM org.hibernate.util.JDBCExceptionReporter logExceptions
Warnung: SQL Error: 1364, SQLState: HY000
Dez 03, 2011 12:58:21 PM org.hibernate.util.JDBCExceptionReporter logExceptions
Schwerwiegend: Field 'describtion' doesn't have a default value
Exception in thread "main" javax.persistence.PersistenceException: org.hibernate.exception.GenericJDBCException: could not insert: [org.idp.persistence.mappings.Consumer]
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1214)
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1147)
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1153)
    at org.hibernate.ejb.AbstractEntityManagerImpl.merge(AbstractEntityManagerImpl.java:695)
    at org.idp.persistence.DataManager.saveOrUpdateEntity(DataManager.java:224)
    at org.idp.persistence.DataManager.saveOrUpdate(DataManager.java:142)
    at org.idp.persistence.mappings.Idpuser.addOrUpdateConsumer(Idpuser.java:259)
    at org.idp.playground.ReadTest.main(ReadTest.java:40)
</pre>

当我尝试从数据库读取它的工作。当我尝试将数据插入另一个表(例如Idpuser)时它也起作用。我还尝试了以下解决方案建议:

  • 为数据库中的描述字段设置默认值
  • -

I have the following Exception when i'm try to insert values in the database.
This is my persistence class:

<pre> 
@SuppressWarnings("serial")
@Entity
@Table(name = "consumer", catalog = "oauth")
@NamedQueries({
    @NamedQuery(name = Consumer.QUERY_BY_CONSUMER_KEY, query = "SELECT i FROM " + Consumer.TABLENAME + " i WHERE i.consumerKey = :" + Consumer.Q_PARAM_CONSUMER_KEY)})
public class Consumer implements java.io.Serializable {

    public static final String TABLENAME = "Consumer";
    public static final String QUERY_BY_CONSUMER_KEY = "ConsumerFindByConsumerKey";
    public static final String Q_PARAM_CONSUMER_KEY = "consumer_key";
    @Id
    @GeneratedValue(strategy = IDENTITY)
    @Column(name = "id", unique = true, nullable = false)
    private Integer id;
    @ManyToOne
    @JoinColumn(name = "user_id", nullable = false)
    private Idpuser idpuser;
    @Column(name = "description", nullable = false, length = 500)
    private String description;
    @Column(name = "consumer_key", nullable = false, length = 100)
    private String consumerKey;
    @Column(name = "consumer_secret", nullable = false, length = 100)
    private String consumerSecret;
    @Column(name = "callbackurl", nullable = false, length = 400)
    private String callbackURL;
    @Column(name = "request_token", length = 500)
    private String requestToken;
    @Column(name = "token_secret", length = 500)
    private String tokenSecret;
    @Column(name = "access_token", length = 500)
    private String accessToken;
    @Temporal(TemporalType.TIMESTAMP)
    @Column(name = "acces_token_valid_from", length = 19)
    private Date accesTokenValidFrom;
    @Temporal(TemporalType.TIMESTAMP)
    @Column(name = "access_token_valid_to", length = 19)
    private Date accessTokenValidTo;
    @Column(name = "access_token_num_usage_count")
    private Integer accessTokenNumUsageCount;
    @Column(name = "access_token_max_usage_count")
    private Integer accessTokenMaxUsageCount;
    @Column(name = "authorized", nullable = false)
    private Boolean authorized;
    @ManyToMany(fetch= FetchType.EAGER)
    @JoinTable(name = "consumer_role_relation",
    joinColumns = { 
      @JoinColumn(name = "consumer_id")
    }, 
    inverseJoinColumns = {
      @JoinColumn(name = "role_id")
    }
    )
    private Set<Role> roles = new HashSet<Role>(0);

    @Column(name = "facebookId", unique = true)
    private BigInteger facebookId;


    protected Consumer() {
    }

    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
    }

    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized,
            Date accesTokenValidFrom, Date accessTokenValidTo, int accessTokenMaxUsageCount) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
        this.accesTokenValidFrom = accesTokenValidFrom;
        this.accessTokenValidTo = accessTokenValidTo;
        this.accessTokenMaxUsageCount = accessTokenMaxUsageCount;
    }

    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized,
            Date accesTokenValidFrom, Date accessTokenValidTo, int accessTokenMaxUsageCount, Set<Role> roles) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
        this.accesTokenValidFrom = accesTokenValidFrom;
        this.accessTokenValidTo = accessTokenValidTo;
        this.accessTokenMaxUsageCount = accessTokenMaxUsageCount;
        this.roles = roles;
    }

    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized,
            Date accesTokenValidFrom, Date accessTokenValidTo) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
        this.accesTokenValidFrom = accesTokenValidFrom;
    }


    public Consumer(Idpuser idpuser, String describtion, String consumerKey, String consumerSecret, String callbackURL,
            String requestToken, String tokenSecret, String accessToken, boolean authorized,
            Date accesTokenValidFrom, Date accessTokenValidTo, Set<Role> roles) {
        this.idpuser = idpuser;
        this.description = describtion;
        this.consumerKey = consumerKey;
        this.consumerSecret = consumerSecret;
        this.callbackURL = callbackURL;
        this.requestToken = requestToken;
        this.tokenSecret = tokenSecret;
        this.accessToken = accessToken;
        this.authorized = authorized;
        this.accesTokenValidFrom = accesTokenValidFrom;
        this.roles = roles;
    }


    public Integer getId() {
        return this.id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public Idpuser getIdpuser() {
        return this.idpuser;
    }

    public void setIdpuser(Idpuser idpuser) {
        this.idpuser = idpuser;
    }

    public String getDescription() {
        return this.description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    public String getConsumerKey() {
        return this.consumerKey;
    }

    public void setConsumerKey(String consumerKey) {
        this.consumerKey = consumerKey;
    }

    public String getConsumerSecret() {
        return this.consumerSecret;
    }

    public void setConsumerSecret(String consumerSecret) {
        this.consumerSecret = consumerSecret;
    }

    public String getCallbackURL() {
        return callbackURL;
    }

    public void setCallbackURL(String callbackURL) {
        this.callbackURL = callbackURL;
    }

    public Date getAccesTokenValidFrom() {
        return accesTokenValidFrom;
    }

    public void setAccesTokenValidFrom(Date accesTokenValidFrom) {
        this.accesTokenValidFrom = accesTokenValidFrom;
    }

    public String getAccessToken() {
        return accessToken;
    }

    public void setAccessToken(String accessToken) {
        this.accessToken = accessToken;
    }

    public Integer getAccessTokenMaxUsageCount() {
        return accessTokenMaxUsageCount;
    }

    public void setAccessTokenMaxUsageCount(Integer accessTokenMaxUsageCount) {
        this.accessTokenMaxUsageCount = accessTokenMaxUsageCount;
    }

    public Integer getAccessTokenNumUsageCount() {
        return accessTokenNumUsageCount;
    }

    public void setAccessTokenNumUsageCount(Integer accessTokenNumUsageCount) {
        this.accessTokenNumUsageCount = accessTokenNumUsageCount;
    }

    public Date getAccessTokenValidTo() {
        return accessTokenValidTo;
    }

    public void setAccessTokenValidTo(Date accessTokenValidTo) {
        this.accessTokenValidTo = accessTokenValidTo;
    }

    public Boolean getAuthorized() {
        return authorized;
    }

    public void setAuthorized(Boolean authorized) {
        this.authorized = authorized;
    }

    public String getRequestToken() {
        return requestToken;
    }

    public void setRequestToken(String requestToken) {
        this.requestToken = requestToken;
    }

    public String getTokenSecret() {
        return tokenSecret;
    }

    public void setTokenSecret(String tokenSecret) {
        this.tokenSecret = tokenSecret;
    }  

    public Set<Role> getRoles(){
        return this.roles;
    }

    public void setRoles(Set<Role> roles){
        this.roles = roles;
    }

    public void addRole(Role r){
        this.roles.add(r);
    }

    public void removeRole(Role r){
        this.roles.remove(r);
    }

    @Override
    public String toString(){
        return this.description;
    }



    /* (non-Javadoc)
     * @see java.lang.Object#hashCode()
     */
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result
                + ((consumerSecret == null) ? 0 : consumerSecret.hashCode());
        return result;
    }

    /* (non-Javadoc)
     * @see java.lang.Object#equals(java.lang.Object)
     */
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        Consumer other = (Consumer) obj;
        if (consumerSecret == null) {
            if (other.consumerSecret != null)
                return false;
        } else if (!consumerSecret.equals(other.consumerSecret))
            return false;
        return true;
    }



    /* ###### Listener handling ###########################  */
    @Transient
    private CopyOnWriteArrayList<Object> listeners = new CopyOnWriteArrayList<Object>();

    public CopyOnWriteArrayList<Object> getListeners() {
        return listeners;
    }

    public void setListeners(CopyOnWriteArrayList<Object> listeners) {
        this.listeners = listeners;
    }

    public BigInteger getFacebookId() {
        return facebookId;
    }

    public void setFacebookId(BigInteger facebookId) {
        this.facebookId = facebookId;
    }    
}

</pre>

Exception:

<pre>
Dez 03, 2011 12:58:21 PM org.hibernate.util.JDBCExceptionReporter logExceptions
Warnung: SQL Error: 1364, SQLState: HY000
Dez 03, 2011 12:58:21 PM org.hibernate.util.JDBCExceptionReporter logExceptions
Schwerwiegend: Field 'describtion' doesn't have a default value
Exception in thread "main" javax.persistence.PersistenceException: org.hibernate.exception.GenericJDBCException: could not insert: [org.idp.persistence.mappings.Consumer]
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1214)
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1147)
    at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1153)
    at org.hibernate.ejb.AbstractEntityManagerImpl.merge(AbstractEntityManagerImpl.java:695)
    at org.idp.persistence.DataManager.saveOrUpdateEntity(DataManager.java:224)
    at org.idp.persistence.DataManager.saveOrUpdate(DataManager.java:142)
    at org.idp.persistence.mappings.Idpuser.addOrUpdateConsumer(Idpuser.java:259)
    at org.idp.playground.ReadTest.main(ReadTest.java:40)
</pre>

When i'm try to read from database it's work. It is also working when i'm try to insert data into another Table (e.g. Idpuser). I'm also tried following solution advices:

  • set default value for the description field in the database
  • -

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

少跟Wǒ拽 2024-12-26 11:28:57

您的表似乎有一列“description”(带有 b),没有默认值,而实体有一个映射到“description”列的字段(带有 p< /代码>)。

确保您的映射与表列匹配。

It seems that your table has a column "describtion" (with a b), without a default value, whereas the entity has a field mapped to the column "description" (with a p).

Make sure your mapping matches with the table columns.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文