Hibernate: java.lang.IllegalArgumentException: невозможно установить поле int - PullRequest
1 голос
/ 02 мая 2019

Im Пытаюсь вставить запись в мою MySQL-базу данных, используя hibernate. Но я получаю исключение IllegalArgumentException. Идентификатор является первичным ключом в моей базе данных, и я проверил параметр автоинкремента.

enter image description here

org.hibernate.property.access.spi.PropertyAccessException: Error accessing field [public int com.nexus.tutorial.Items.id] by reflection for persistent property [com.nexus.tutorial.Items#id] : Items [name=test, price=20.0, lagerstand=5, anfver=ankauf, position=0,0,0]
...
...
...
Caused by: java.lang.IllegalArgumentException: Can not set int field com.nexus.tutorial.Items.id to com.nexus.tutorial.Items
        at sun.reflect.UnsafeFieldAccessorImpl.throwSetIllegalArgumentException(UnsafeFieldAccessorImpl.java:167)
        at sun.reflect.UnsafeFieldAccessorImpl.throwSetIllegalArgumentException(UnsafeFieldAccessorImpl.java:171)
        at sun.reflect.UnsafeFieldAccessorImpl.ensureObj(UnsafeFieldAccessorImpl.java:58)
        at sun.reflect.UnsafeIntegerFieldAccessorImpl.getInt(UnsafeIntegerFieldAccessorImpl.java:56)
        at java.lang.reflect.Field.getInt(Field.java:574)
        at org.hibernate.property.access.spi.GetterFieldImpl.get(GetterFieldImpl.java:62)
public class HibernateUpdate {

    public static void update(Items item) {

        SessionFactory factory = new Configuration()
                .configure("C:\\Users\\N3XUS\\AppData\\\\Roaming\\.minecraft\\config\\hibernate.cfg.xml")
                .addAnnotatedClass(Items.class)
                .buildSessionFactory();

        Session session = factory.getCurrentSession();

        try {
            System.out.println("Creating new Items");
            session.beginTransaction();
            //List<Items> itemList = session.createQuery("from Items").list();
            session.save(item);
            session.getTransaction().commit();

        }finally {
            factory.close();
        }
    }

}

вот как я называю метод:

HibernateUpdate.update(new Items("test", 20.00, 5,"ankauf","0,0,0"));

а это моя модель:

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name="items")
public class Items {

    @Id
    @Column(name="id")
    public int id;

    @Column(name="name")
    public String name;

    @Column(name="price")
    public double price;

    @Column(name="lagerstand")
    public int lagerstand;

    @Column(name="anfver")
    public String anfver;

    @Column(name="position")
    public String position;

    public Items() {

    }

    public Items(String name, double price, int lagerstand, String anfver, String position) {
        this.name = name;
        this.price = price;
        this.lagerstand = lagerstand;
        this.anfver = anfver;
        this.position = position;
    }

    public int getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    public int getLagerstand() {
        return lagerstand;
    }

    public void setLagerstand(int lagerstand) {
        this.lagerstand = lagerstand;
    }

    public String getAnfver() {
        return anfver;
    }

    public void setAnfver(String anfver) {
        this.anfver = anfver;
    }

    public String getPosition() {
        return position;
    }

    public void setPosition(String position) {
        this.position = position;
    }

    @Override
    public String toString() {
        return "Items [name=" + name + ", price=" + price + ", lagerstand=" + lagerstand + ", anfver=" + anfver
                + ", position=" + position + "]";
    }

}

Модификатор должен быть закрытым, я знаю. Я использую последние версии для JDBC и hibernate из репозитория maven.

    compile 'org.hibernate:hibernate-agroal:5.3.10.Final'
compile group: 'mysql', name: 'mysql-connector-java', version: '8.0.15'

1 Ответ

1 голос
/ 03 мая 2019

Вы должны использовать GeneratedValue, чтобы обеспечить автоматическое увеличение вашего идентификатора:

@Id @GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="id")
public int id;

, после этого ваш идентификатор будет автоматически увеличен, и вы можете добавить свой элемент:

HibernateUpdate.update(new Items("test", 20.00, 5,"ankauf","0,0,0"));

Совет: ваши атрибуты в настройках должны быть приватными или защищенными, и вы можете получить к ним доступ из геттера и сеттера.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...