Как исправить ошибку с JpaRepository, не сохраняйте, и хранилище было пустым - PullRequest
0 голосов
/ 03 апреля 2019

Мне нужна помощь с загрузочным приложением Spring. Я создаю репозиторий и расширяю JpaRepositoy, когда я создаю экземпляр моего репозитория с помощью @Autowired, мой репозиторий по-прежнему равен нулю, и я не могу сохранить данные из своей базы данных.

Мой контроллер

@Controller
public class ListenerURLImpl extends HttpServlet implements ListenerURL {

    private static final long serialVersionUID = 1L;

    @Autowired
    DataBaseConfig dataBaseConfig;

    @Autowired
    ListenerConfig fila;

    @Autowired
    DataRepository repository;

    @Autowired
    SenderDatasImpl senderDatasImpl;

//some another methods
public ResponseEntity<List<DBDados>> inputDados(@Valid @RequestBody DataPegaDTO mensagem,
            DataRepository repository) throws JsonProcessingException {
        try {
            HttpStatus status;
            this.repository = repository;
            status = senderDatasImpl.receiverDatas(mensagem, this.repository);
            if (status == HttpStatus.OK) {
                return new ResponseEntity<>(this.repository.findAll(), HttpStatus.OK);
            } else {
                return null;
            }
        } catch (Exception e) {
            LOGGER.error("Erro ao fazer ao inserir dados no banco de dados {} " + mensagem);
            System.out.println("Erro ao inserir os dados {} " + e);
            return null;
        }
    }

Мой репозиторий

@Repository
public interface DataRepository extends JpaRepository<DBDados, String> {

    @Query(value = "select * from proposta_andamento where id_cliente = :id_cliente", nativeQuery = true)
    List<DBDados> findClient(@Param("id_cliente") String id_cliente);

    @Query(value = "select * from proposta_andamento where proposta = :proposta and produto = :produto", nativeQuery = true)
    List<DBDados> findContrato(@Param("proposta") String proposta, @Param("produto") String produto);

    @Query(value = "select * from proposta_andamento where proposta = :proposta and produto = :produto and subProduto = :subProduto", nativeQuery = true)
    List<DBDados> findAProposal(@Param("proposta") String proposta, @Param("produto") String produto,
            @Param("subProduto") String subProduto);

}

Мой класс, который вызывает repository.save (Entity)

public HttpStatus receiverDatas(DataPegaDTO data, DataRepository repository) {
        try {
            DBDados save = new DBDados(data);
            DBDados status = null;
            status = repository.save(save);
            if (status != null) {
                System.out.println("Find All -> " + repository.findAll());
                return HttpStatus.OK;
            } else {
                return HttpStatus.ALREADY_REPORTED;
            }
        } catch (Exception e) {
            System.out.println("Erro na hora de salvar no banco de dados: " + e);
            return HttpStatus.BAD_REQUEST;
        }
    }

Я ожидал для результата HttpStatus.OK, но у меня есть эта ошибка:

2019-04-03 15:29:48 WARN  o.h.e.jdbc.spi.SqlExceptionHelper - SQL Error: 90079, SQLState: 90079
2019-04-03 15:29:48 ERROR o.h.e.jdbc.spi.SqlExceptionHelper - Schema "PROPOSTA_ANDAMENTO" not found; SQL statement:
select dbdados0_.data_inicio as data_ini1_0_0_,...and dbdados0_.proposta=? and dbdados0_.subProduto=? [90079-197]
2019-04-03 15:29:48 INFO  o.h.e.i.DefaultLoadEventListener - HHH000327: Error performing load command : org.hibernate.exception.GenericJDBCException: could not prepare statement
Erro na hora de salvar no banco de dados: org.springframework.orm.jpa.JpaSystemException: could not prepare statement; nested exception is org.hibernate.exception.GenericJDBCException: could not prepare statement
2019-04-03 15:29:48 ERROR b.c.s.e.m.l.r.DataRepository - Proposta já existente no banco! Dados: {}DataPegaDTO(id_cliente=123, produto=produto, subProduto=subproduto, nomeCliente=teste, dataInicio=Fri Mar 22 09:58:48 BRT 2019, dataFim=Fri Mar 22 09:58:48 BRT 2019, dataExpurgo=Fri Mar 22 09:58:48 BRT 2019, id_caso=idCaso, plataforma=plataforma, status=Ativo, fase_negocio=64, contrato=1234567, vl_contrato=10.0, vl_negocio1=11.0, vl_negocio2=12.0, vl_negocio3=13.0, vl_negocio4=14.0, vl_negocio5=0.0, negocio1=negocio1, negocio2=negocio2, negocio3=negocio3, negocio4=negocio4, negocio5=negocio5, negocio6=negocio6, negocio7=negocio7, negocio8=negocio8, negocio9=negocio9, negocio10=negocio10, negocio11=null, negocio12=null, negocio13=null, negocio14=null, negocio15=null, negocio16=null, negocio17=null, negocio18=null, negocio19=null, negocio20=null, id_inclusao=x213432, id_alteracao=null)

1 Ответ

2 голосов
/ 03 апреля 2019
Schema "PROPOSTA_ANDAMENTO" not found

Возможно, вы неправильно написали имя схемы в свойствах вашего соединения (application.properties файл)?

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