Why is just this one field of a Hibernate controlled object/entity not being created or updated?
I have an object "Chemical" that is updated according to entries in an HTML page. The data is returned to the Java code correctly, yet this one field is not updating or being created in the database. The chemical entity is defined as follows:
@Entity
@NamedQuery(name="Chemical.findAll", query="SELECT c FROM Chemical c")
public class Chemical implements Serializable {
@Id
@Column(name="chemical_id")
@GeneratedValue(strategy=GenerationType.IDENTITY)
private int chemicalId;
...
private string formula; <--- THE FIELD THAT WILL NOT UPDATE/BE CREATED
....
public void setFormula(String formula) {
this.formula = formula;
}
public String getFormula() {
return this.formula;
}
.....
The Java code that actually saves/updates the database:
public void saveOrUpdate(final T data) throws CPDPersistenceException {
final EntityManager em = getEntityManager();
try {
final EntityTransaction transaction = em.getTransaction();
transaction.begin();
em.merge(data);
transaction.commit();
} catch (final PersistenceException e) {
throw new PersistenceException(e);
}
}
After the code is executed, other fields have changed in the database if changes have been made. However, "formula" is not changed and remains a NULL field. Can anybody see why?
java hibernate jpa
add a comment |
I have an object "Chemical" that is updated according to entries in an HTML page. The data is returned to the Java code correctly, yet this one field is not updating or being created in the database. The chemical entity is defined as follows:
@Entity
@NamedQuery(name="Chemical.findAll", query="SELECT c FROM Chemical c")
public class Chemical implements Serializable {
@Id
@Column(name="chemical_id")
@GeneratedValue(strategy=GenerationType.IDENTITY)
private int chemicalId;
...
private string formula; <--- THE FIELD THAT WILL NOT UPDATE/BE CREATED
....
public void setFormula(String formula) {
this.formula = formula;
}
public String getFormula() {
return this.formula;
}
.....
The Java code that actually saves/updates the database:
public void saveOrUpdate(final T data) throws CPDPersistenceException {
final EntityManager em = getEntityManager();
try {
final EntityTransaction transaction = em.getTransaction();
transaction.begin();
em.merge(data);
transaction.commit();
} catch (final PersistenceException e) {
throw new PersistenceException(e);
}
}
After the code is executed, other fields have changed in the database if changes have been made. However, "formula" is not changed and remains a NULL field. Can anybody see why?
java hibernate jpa
You need to add@Column(name="formula")
above the variable.
– Jake Stewart
Nov 20 at 20:03
I'll try that, but there are a bunch of other fields that are being populated correctly that do not have the @Column(name = WHATEVER) line above them.
– calvinnme
Nov 20 at 20:31
Nope, you don't need to define the@Column
on a field ... JPA defines defaults (read the JPA spec if not believing me).@Basic
is the most that could be needed but most JPA providers don't require that since String is a supported type
– Billy Frost
Nov 21 at 8:45
Also your post doesnt say whether the object is already persistent, whether you created the schema before adding that field, what the schema is, what SQL is invoked when you invoke a JPA operation. All of this is basic info for debugging
– Billy Frost
Nov 21 at 8:59
add a comment |
I have an object "Chemical" that is updated according to entries in an HTML page. The data is returned to the Java code correctly, yet this one field is not updating or being created in the database. The chemical entity is defined as follows:
@Entity
@NamedQuery(name="Chemical.findAll", query="SELECT c FROM Chemical c")
public class Chemical implements Serializable {
@Id
@Column(name="chemical_id")
@GeneratedValue(strategy=GenerationType.IDENTITY)
private int chemicalId;
...
private string formula; <--- THE FIELD THAT WILL NOT UPDATE/BE CREATED
....
public void setFormula(String formula) {
this.formula = formula;
}
public String getFormula() {
return this.formula;
}
.....
The Java code that actually saves/updates the database:
public void saveOrUpdate(final T data) throws CPDPersistenceException {
final EntityManager em = getEntityManager();
try {
final EntityTransaction transaction = em.getTransaction();
transaction.begin();
em.merge(data);
transaction.commit();
} catch (final PersistenceException e) {
throw new PersistenceException(e);
}
}
After the code is executed, other fields have changed in the database if changes have been made. However, "formula" is not changed and remains a NULL field. Can anybody see why?
java hibernate jpa
I have an object "Chemical" that is updated according to entries in an HTML page. The data is returned to the Java code correctly, yet this one field is not updating or being created in the database. The chemical entity is defined as follows:
@Entity
@NamedQuery(name="Chemical.findAll", query="SELECT c FROM Chemical c")
public class Chemical implements Serializable {
@Id
@Column(name="chemical_id")
@GeneratedValue(strategy=GenerationType.IDENTITY)
private int chemicalId;
...
private string formula; <--- THE FIELD THAT WILL NOT UPDATE/BE CREATED
....
public void setFormula(String formula) {
this.formula = formula;
}
public String getFormula() {
return this.formula;
}
.....
The Java code that actually saves/updates the database:
public void saveOrUpdate(final T data) throws CPDPersistenceException {
final EntityManager em = getEntityManager();
try {
final EntityTransaction transaction = em.getTransaction();
transaction.begin();
em.merge(data);
transaction.commit();
} catch (final PersistenceException e) {
throw new PersistenceException(e);
}
}
After the code is executed, other fields have changed in the database if changes have been made. However, "formula" is not changed and remains a NULL field. Can anybody see why?
java hibernate jpa
java hibernate jpa
asked Nov 20 at 19:50
calvinnme
114
114
You need to add@Column(name="formula")
above the variable.
– Jake Stewart
Nov 20 at 20:03
I'll try that, but there are a bunch of other fields that are being populated correctly that do not have the @Column(name = WHATEVER) line above them.
– calvinnme
Nov 20 at 20:31
Nope, you don't need to define the@Column
on a field ... JPA defines defaults (read the JPA spec if not believing me).@Basic
is the most that could be needed but most JPA providers don't require that since String is a supported type
– Billy Frost
Nov 21 at 8:45
Also your post doesnt say whether the object is already persistent, whether you created the schema before adding that field, what the schema is, what SQL is invoked when you invoke a JPA operation. All of this is basic info for debugging
– Billy Frost
Nov 21 at 8:59
add a comment |
You need to add@Column(name="formula")
above the variable.
– Jake Stewart
Nov 20 at 20:03
I'll try that, but there are a bunch of other fields that are being populated correctly that do not have the @Column(name = WHATEVER) line above them.
– calvinnme
Nov 20 at 20:31
Nope, you don't need to define the@Column
on a field ... JPA defines defaults (read the JPA spec if not believing me).@Basic
is the most that could be needed but most JPA providers don't require that since String is a supported type
– Billy Frost
Nov 21 at 8:45
Also your post doesnt say whether the object is already persistent, whether you created the schema before adding that field, what the schema is, what SQL is invoked when you invoke a JPA operation. All of this is basic info for debugging
– Billy Frost
Nov 21 at 8:59
You need to add
@Column(name="formula")
above the variable.– Jake Stewart
Nov 20 at 20:03
You need to add
@Column(name="formula")
above the variable.– Jake Stewart
Nov 20 at 20:03
I'll try that, but there are a bunch of other fields that are being populated correctly that do not have the @Column(name = WHATEVER) line above them.
– calvinnme
Nov 20 at 20:31
I'll try that, but there are a bunch of other fields that are being populated correctly that do not have the @Column(name = WHATEVER) line above them.
– calvinnme
Nov 20 at 20:31
Nope, you don't need to define the
@Column
on a field ... JPA defines defaults (read the JPA spec if not believing me). @Basic
is the most that could be needed but most JPA providers don't require that since String is a supported type– Billy Frost
Nov 21 at 8:45
Nope, you don't need to define the
@Column
on a field ... JPA defines defaults (read the JPA spec if not believing me). @Basic
is the most that could be needed but most JPA providers don't require that since String is a supported type– Billy Frost
Nov 21 at 8:45
Also your post doesnt say whether the object is already persistent, whether you created the schema before adding that field, what the schema is, what SQL is invoked when you invoke a JPA operation. All of this is basic info for debugging
– Billy Frost
Nov 21 at 8:59
Also your post doesnt say whether the object is already persistent, whether you created the schema before adding that field, what the schema is, what SQL is invoked when you invoke a JPA operation. All of this is basic info for debugging
– Billy Frost
Nov 21 at 8:59
add a comment |
1 Answer
1
active
oldest
votes
There is I think a difference between UPDATE and CREATE.
Try to replace em.merge(data) with em.persist(data)
Does it save the content the first time you create a new row with persist ?
What is the length of your string definition in the database ?
Check the database logs whenever the HQL is run from your code, do the log complain at one point during the persist ?
It might be necessary to first test if the row exists before you can run a merge.
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53400533%2fwhy-is-just-this-one-field-of-a-hibernate-controlled-object-entity-not-being-cre%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
There is I think a difference between UPDATE and CREATE.
Try to replace em.merge(data) with em.persist(data)
Does it save the content the first time you create a new row with persist ?
What is the length of your string definition in the database ?
Check the database logs whenever the HQL is run from your code, do the log complain at one point during the persist ?
It might be necessary to first test if the row exists before you can run a merge.
add a comment |
There is I think a difference between UPDATE and CREATE.
Try to replace em.merge(data) with em.persist(data)
Does it save the content the first time you create a new row with persist ?
What is the length of your string definition in the database ?
Check the database logs whenever the HQL is run from your code, do the log complain at one point during the persist ?
It might be necessary to first test if the row exists before you can run a merge.
add a comment |
There is I think a difference between UPDATE and CREATE.
Try to replace em.merge(data) with em.persist(data)
Does it save the content the first time you create a new row with persist ?
What is the length of your string definition in the database ?
Check the database logs whenever the HQL is run from your code, do the log complain at one point during the persist ?
It might be necessary to first test if the row exists before you can run a merge.
There is I think a difference between UPDATE and CREATE.
Try to replace em.merge(data) with em.persist(data)
Does it save the content the first time you create a new row with persist ?
What is the length of your string definition in the database ?
Check the database logs whenever the HQL is run from your code, do the log complain at one point during the persist ?
It might be necessary to first test if the row exists before you can run a merge.
answered Nov 20 at 21:04
Apollo
362
362
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53400533%2fwhy-is-just-this-one-field-of-a-hibernate-controlled-object-entity-not-being-cre%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
You need to add
@Column(name="formula")
above the variable.– Jake Stewart
Nov 20 at 20:03
I'll try that, but there are a bunch of other fields that are being populated correctly that do not have the @Column(name = WHATEVER) line above them.
– calvinnme
Nov 20 at 20:31
Nope, you don't need to define the
@Column
on a field ... JPA defines defaults (read the JPA spec if not believing me).@Basic
is the most that could be needed but most JPA providers don't require that since String is a supported type– Billy Frost
Nov 21 at 8:45
Also your post doesnt say whether the object is already persistent, whether you created the schema before adding that field, what the schema is, what SQL is invoked when you invoke a JPA operation. All of this is basic info for debugging
– Billy Frost
Nov 21 at 8:59