У меня есть следующий код:
@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