我有这个实体:

@Entity
@Table
public class Terminals implements Serializable {

    private static final long serialVersionUID = 5288308199642977991L;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "id", updatable = false, nullable = false)
    private Long id;

    @Column
    private int merchant_id;

    @Column
    private String terminalToken;

.....
}


我尝试使用此查询:

public Terminals getTerminalToken(String terminalToken) throws Exception {
        return entityManager.find(Terminals.class, terminalToken);
    }


看起来它只是在选择表键。

如何选择表列terminalToken

最佳答案

您最好使用Spring dataJPA Repositories一起构建查询。您只需要扩展JpaRepository接口,并遵循命名约定来命名您的方法。

您的方法将如下所示:

public List<Terminal> findByTeminalToken(String TerminalToken);


否则,您将需要使用entityManager.createQuery()方法而不是entityManager.find(),因为后者仅与id列一起使用。

08-03 21:40