Hibernate генерирует запрос SQL с ключевым словом «as» для таблицы, который генерирует ORA-00933 в Oracle 12c - PullRequest
0 голосов
/ 10 марта 2020

У меня есть следующий код:

@Stateless
public class UsersStore {
    public User getUserByUsernameAndPassword(String username, String password) {
        if (username == null || password == null) {
            return null;
        }

        try (Session session = HibernateUtil.getSessionFactoryInstance().openSession()) {

            final Query<User> query = session.createQuery(
                    "select u from User u where u.username = :username and u.password = :password", User.class);

            query.setParameter("username", username);
            query.setParameter("password", password);

            return query.getSingleResult();
        }

    }
}
@Entity
@Table(name = "HARPIA_USER")
public class User {
    @Id
    @GeneratedValue
    private long id;
    @NotNull
    private String username;
    @NotNull
    private String password;

    public User(String username, String password) {
        super();
        this.username = username;
        this.password = password;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}

Приведенный выше код генерирует следующее SQL:

select u1_0.id, u1_0.password, u1_0.username from HARPIA_USER as u1_0 where u1_0.username = ? and u1_0.password = ?

This SQL генерирует ORA-00933: SQL command not properly ended. Причина этого в том, что Oracle не принимает ключевое слово AS для таблицы, по крайней мере, у меня есть версия, Oracle 12 c.

Это обходной путь для решения этой проблемы. Могу ли я указать hibernate пропустить ключевое слово AS? И, удаляя, я не говорю, чтобы избавиться от псевдонимов.

Hibernate версия: 6.0.0.Alpha4

Ответы [ 2 ]

0 голосов
/ 15 марта 2020

Проблема исчезла после того, как я снизил версию Hibernate до 5.4.12. Окончательный вариант.

0 голосов
/ 10 марта 2020

Стандартное поведение Hibernate нечувствительно к регистру, но Oracle по умолчанию чувствительно к UPPERCASE, поэтому попробуйте установить параметры в верхнем регистре

UPD

Сначала попробуйте изменить имена свойств в верхнем регистре в запросе, но, честно говоря, это действительно зависит от ваших настроек Ora

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