Spring Boot Project - проблема с написанием JPQL (Intellij) - PullRequest
0 голосов
/ 29 сентября 2018

Итак, я настроил проект начальной загрузки, с помощью которого я хотел бы создать несколько конкретных запросов.

Очень просто, я просто хочу выполнить оператор выбора:

public class UserRepositoryCustomImpl implements UserRepositoryCustom {

    @PersistenceContext
    private EntityManager entityManager;


    public User findUserByEmail(String email) {
        Query nativeQuery = entityManager.createQuery("select e from User");
        nativeQuery.getFirstResult();
        return new User();
    }

}

В Intellij, когда я наводю курсор мыши на пользователя, он говорит, что не может resolve symbol for User, у меня был гугл, и в большинстве ответов говорится, что вам нужно использовать имя объекта, что, конечно, я и сделал:

@Entity(name = "PG_user")
public class User extends AbstractEntity {

    @Column
    private String email;

    @Column
    private String password;

    public User(){}

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getPassword() {
        return password;
    }

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

Вот и мой POM, если это поможет:

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>


        <!-- https://mvnrepository.com/artifact/org.modelmapper/modelmapper -->
        <dependency>
            <groupId>org.modelmapper</groupId>
            <artifactId>modelmapper</artifactId>
            <version>0.3.5</version>
        </dependency>


        <!-- https://mvnrepository.com/artifact/com.microsoft.sqlserver/mssql-jdbc -->
        <dependency>
            <groupId>com.microsoft.sqlserver</groupId>
            <artifactId>mssql-jdbc</artifactId>
            <version>6.2.2.jre8</version>
        </dependency>


        <!-- https://mvnrepository.com/artifact/org.webjars.bower/angular-bootstrap-contextmenu -->
        <dependency>
            <groupId>org.webjars.bower</groupId>
            <artifactId>angular-bootstrap-contextmenu</artifactId>
            <version>0.9.7</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.springframework.security/spring-security-crypto -->
        <dependency>
            <groupId>org.springframework.security</groupId>
            <artifactId>spring-security-crypto</artifactId>
            <version>3.1.0.RELEASE</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.hibernate.javax.persistence/hibernate-jpa-2.0-api -->
        <dependency>
            <groupId>org.hibernate.javax.persistence</groupId>
            <artifactId>hibernate-jpa-2.0-api</artifactId>
            <version>1.0.1.Final</version>
        </dependency>


    </dependencies>

1 Ответ

0 голосов
/ 29 сентября 2018

Но имя вашей сущности - PG_user

@Entity(name = "PG_user")
public class User extends AbstractEntity {

Атрибут name определяет имя сущности, которое вы должны использовать для запроса.

Но я предполагаю, что вы хотите установитьимя таблицы.

Это будет

@Table(name = "PG_user")
@Entity
public class User extends AbstractEntity {
...