it-swarm.com.de

So erstellen Sie eine Einfügeabfrage in JPA

Ich versuche, Daten in eine Tabelle mit den Spalten (NAME, VALUE) mit einzufügen 

Query query = em.createQuery("INSERT INTO TestDataEntity (NAME, VALUE) VALUES (:name, :value)");
query.setParameter("name", name);
query.setParameter("value", value);
query.executeUpdate();

und die folgende Ausnahme erhalten:

ERROR org.hibernate.hql.internal.ast.ErrorCounter - line 1:42: unexpected token: VALUES 

Ich kann auch keinen Datensatz mit einer systemeigenen Abfrage einfügen:

Query query = em.createNativeQuery("INSERT INTO TEST_DATA (NAME, VALUE) VALUES (:name, :value);");
query.setParameter("name", name);
query.setParameter("value", value);
query.executeUpdate();

Eine andere Ausnahme wird geworfen:

javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: could not execute statement

Die Frage ist:

  • Was stimmt nicht mit der Abfragezeichenfolge?

Danke vielmals.

6
Armine

Ich habe das Problem gelöst.

Nach this

Es gibt keine INSERT-Anweisung in JPA.

Aber ich könnte das Problem mit der nativen Abfrage lösen: Ich habe irrtümlich einen Redundanten eingesetzt; am Ende der Abfrage, so dass das Problem durch das Entfernen gelöst wurde.

10
Armine

Ich habe zwei Beispiele gefunden, bei denen der Autor das Insert in einer systemeigenen Abfrage verwendet ( first und second ). Dann könnte Ihre Anfrage lauten:

Query query = em.createQuery("INSERT INTO TestDataEntity (NAME, VALUE) VALUES (?, ?)");
query.setParameter(1, name);
query.setParameter(2, value);
query.executeUpdate();

Versuche dies.

1

Ich war in der Lage, dies mit dem folgenden zu tun - ich hatte gerade einen Tabellennamen Fahrrad mit 2 Feldern ID und Name. Ich habe das Folgende benutzt, um das in die Datenbank einzufügen.

Query query = em.createNativeQuery("INSERT INTO Bike (id, name) VALUES (:id , :name);");
em.getTransaction().begin();
query.setParameter("id", "5");
query.setParameter("name", "Harley");
query.executeUpdate();
em.getTransaction().commit();
0
Rajdeep Singh