JHipster-使用GET方法插入数据库中

问题描述 投票:0回答:1

我必须使用Jhipster创建一个应用程序,但我从未使用过它。当用户向地址http://localhost:8080/api/newmesure/ {mac-address} / {value}发送GET请求时我想在数据库中插入新的度量。

首先,我以这种格式创建了3个实体“ Plantes”,“ Capteurs”和“ Mesures”:

此处的图片:https://i.stack.imgur.com/zJqia.png(不允许发布)

我激活了JPA筛选以创建一个@Query来在数据库中插入数据,但我读到这是不可能的。

在/src/main/java/com/mycompany/myapp/web/rest/MesuresRessources.java中:

/**
 * REST controller for managing {@link com.mycompany.myapp.domain.Mesures}.
 */
@RestController
@RequestMapping("/api")
public class MesuresResource {

    private final Logger log = LoggerFactory.getLogger(MesuresResource.class);

    private static final String ENTITY_NAME = "mesures";

    @Value("${jhipster.clientApp.name}")
    private String applicationName;

    private final MesuresService mesuresService;

    private final MesuresQueryService mesuresQueryService;

    public MesuresResource(MesuresService mesuresService, MesuresQueryService mesuresQueryService) {
        this.mesuresService = mesuresService;
        this.mesuresQueryService = mesuresQueryService;
    }


    @GetMapping("/newMesure/{mac}/{value}")
    public String newMesure(@PathVariable String mac,@PathVariable int value) {

      log.debug("Adresse MAC : "+mac);
      log.debug("Valeur : "+value);

      @Query("SELECT valeur FROM Mesures WHERE id = 1") //not working
      Mesures getValeur(); //not working

      return "Mesure ajoutée";

    }
}

在/src/main/java/com/mycompany/myapp/domain/Mesures.java中:

/**
 * A Mesures.
 */
@Entity
@Table(name = "mesures")
public class Mesures implements Serializable {

    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column(name = "valeur")
    private Integer valeur;

    @ManyToOne(optional = false)
    @NotNull
    @JsonIgnoreProperties("macs")
    private Capteurs mac;

    // jhipster-needle-entity-add-field - JHipster will add fields here, do not remove
    public Long getId() {
        return id;
    }

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

    public Integer getValeur() {
        return valeur;
    }

    public Mesures valeur(Integer valeur) {
        this.valeur = valeur;
        return this;
    }

    public void setValeur(Integer valeur) {
        this.valeur = valeur;
    }

    public Capteurs getMac() {
        return mac;
    }

    public Mesures mac(Capteurs capteurs) {
        this.mac = capteurs;
        return this;
    }

    public void setMac(Capteurs capteurs) {
        this.mac = capteurs;
    }
    // jhipster-needle-entity-add-getters-setters - JHipster will add getters and setters here, do not remove

    @Override
    public boolean equals(Object o) {
        if (this == o) {
            return true;
        }
        if (!(o instanceof Mesures)) {
            return false;
        }
        return id != null && id.equals(((Mesures) o).id);
    }

    @Override
    public int hashCode() {
        return 31;
    }

    @Override
    public String toString() {
        return "Mesures{" +
            "id=" + getId() +
            ", valeur=" + getValeur() +
            "}";
    }
}

非常感谢您阅读。我学习用C和C ++进行编码,但这是我第一次使用Java。我阅读了有关Java,javaEE和spring-boot的课程,但是Jhipster对我来说是一个真正的迷宫。

贷款

spring-boot jhipster
1个回答
0
投票

使用JHipster学习Java可能不是一个明智的主意,它使用了非常丰富的技术堆栈,除非您投入足够的时间来学习基础知识,否则可能会迷失您。

您的代码和方法中有很多错误:

  • 您不能在REST控制器的方法a的主体内使用@Query批注,它必须在@Repository接口中使用,此代码无法编译。参见https://www.baeldung.com/spring-data-jpa-query快速介绍
  • JPA筛选与插入数据库无关
  • 在HTTP / REST中,GET方法应该是幂等的。要在数据库中进行更改,应使用POST或PUT方法。参见What is idempotency in HTTP methods?
  • 您的实体命名约定不一致:对于实体类,请使用单数形式,因为每个实体对象代表一个Mesure实例。表名称使用复数形式,因为它包含所有的Mesure行
© www.soinside.com 2019 - 2024. All rights reserved.