Как вставить Java значение даты и времени в mysql данные весной - PullRequest
1 голос
/ 19 февраля 2020

Я пытаюсь создать страницу регистрации для добавления сведений о рейсе, но пытаюсь вставить дату и время в базу данных mysql, но получаю ошибочное отклоненное значение [22-02-2020]; и отклоненное значение [12:00]; , может кто-нибудь подскажет мне, как решить эту проблему.

Класс модели моего полета

@Entity
@Table(name="FLIGHT")
public class Flight {

    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    private int ID;
    private String flightnumber;
    @Column(name="operatingairlines")
    private String operatingAirlines;
    @Column(name="departurecity")
    private String departureCity;
    @Column(name="arrivalcity")
    private String arivalCity;
    @Column(name="departuredate")
    @DateTimeFormat(pattern = "yyyy-MM-dd")
    private Date dateOfDeparture;
    @Column(name="departuretime")
    private Timestamp estimatedTravelTime;

    public int getID() {
        return ID;
    }

    public void setID(int iD) {
        ID = iD;
    }

    public String getFlightnumber() {
        return flightnumber;
    }

    public void setFlightnumber(String flightnumber) {
        this.flightnumber = flightnumber;
    }

    public String getOperatingAirlines() {
        return operatingAirlines;
    }

    public void setOperatingAirlines(String operatingAirlines) {
        this.operatingAirlines = operatingAirlines;
    }

    public String getDepartureCity() {
        return departureCity;
    }

    public void setDepartureCity(String departureCity) {
        this.departureCity = departureCity;
    }

    public String getArivalCity() {
        return arivalCity;
    }

    public void setArivalCity(String arivalCity) {
        this.arivalCity = arivalCity;
    }

    public Date getDateOfDeparture() {
        return dateOfDeparture;
    }

    public void setDateOfDeparture(Date dateOfDeparture) {
        this.dateOfDeparture = dateOfDeparture;
    }

    public Timestamp getEstimatedTravelTime() {
        return estimatedTravelTime;
    }

    public void setEstimatedTravelTime(Timestamp estimatedTravelTime) {
        this.estimatedTravelTime = estimatedTravelTime;
    }

    @Override
    public String toString() {
        return "Flight [ID=" + ID + ", flightnumber=" + flightnumber + ", operatingAirlines=" + operatingAirlines
                + ", departureCity=" + departureCity + ", arivalCity=" + arivalCity + ", dateOfDeparture="
                + dateOfDeparture + ", estimatedTravelTime=" + estimatedTravelTime + "]";
    }

}

Контроллер входа

package com.tcd c .FlightReservation.controller;

@Controller
public class LoginController {

    @Autowired
    UserRepository userRepository;


    @GetMapping("/showform")
    public String showRegistration() {
        return "register";
    }

    @PostMapping("/registerUser")
    public String SaveRegister(@ModelAttribute("user") User user) {
        //user.setPassword(bCryptPasswordEncoder.encode(user.getPassword()));
        System.out.println(user);
        userRepository.save(user);
        return "login";
    }

    @GetMapping("/showlogin")
    public String showLogin() {
        //userRepository.
        return "login";
    }

    @PostMapping("/LoginProcess")
    public String LoginProcess(@RequestParam("email") String email, @RequestParam("password") String password) {

        User user = userRepository.findByEmail(email);
        System.out.println(user);
        if((user.getPassword().equals(password))&&(user.getRole().contentEquals("0"))) {
            return "findFlights";
        }
        else if((user.getPassword().equals(password))&&(user.getRole().contentEquals("1"))) {
            return "AddFlight";
        }
        else {
        return "login";
        }

    }

}

FlightController

@Controller
public class FlightController {

    @Autowired
    FlightServices flightServices;

    @Autowired
    FlightRepository flightRepository;

    @PostMapping("/flightResult")
    public String findFlights(@RequestParam("from") String from,@RequestParam("to") String to,@RequestParam("departureDate") @DateTimeFormat(pattern="dd-MM-yyyy") Date departureDate, Model model) {

        //flightRepository.findFlight(from,to,departureDate);
        System.out.println(from+" "+to+" "+departureDate);
        List<Flight> flist = flightServices.searchFlight(from,to,departureDate);
        model.addAttribute("flightdetails", flist);
        System.out.println(flist);
        return "FlightResults";
    }


    @PostMapping("/SaveFlight")
    public String SaveFlight(@ModelAttribute("flight") Flight flight) {

        flight.getDateOfDeparture();

                    //flightRepository.save(flight);


        return "FlightResults";
    }


}

Ошибка

2020-02-19 20:02:35.580  WARN 3048 --- [nio-8080-exec-7] .w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.validation.BindException: org.springframework.validation.BeanPropertyBindingResult: 2 errors
Field error in object 'flight' on field 'dateOfDeparture': rejected value [22-02-2020]; codes [typeMismatch.flight.dateOfDeparture,typeMismatch.dateOfDeparture,typeMismatch.java.util.Date,typeMismatch]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [flight.dateOfDeparture,dateOfDeparture]; arguments []; default message [dateOfDeparture]]; default message [Failed to convert property value of type 'java.lang.String' to required type 'java.util.Date' for property 'dateOfDeparture'; nested exception is org.springframework.core.convert.ConversionFailedException: Failed to convert from type [java.lang.String] to type [@javax.persistence.Column @org.springframework.format.annotation.DateTimeFormat java.util.Date] for value '22-02-2020'; nested exception is java.lang.IllegalArgumentException: Parse attempt failed for value [22-02-2020]]
Field error in object 'flight' on field 'estimatedTravelTime': rejected value [12:00]; codes [typeMismatch.flight.estimatedTravelTime,typeMismatch.estimatedTravelTime,typeMismatch.java.sql.Timestamp,typeMismatch]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [flight.estimatedTravelTime,estimatedTravelTime]; arguments []; default message [estimatedTravelTime]]; default message [Failed to convert property value of type 'java.lang.String' to required type 'java.sql.Timestamp' for property 'estimatedTravelTime'; nested exception is org.springframework.core.convert.ConversionFailedException: Failed to convert from type [java.lang.String] to type [@javax.persistence.Column java.sql.Timestamp] for value '12:00'; nested exception is java.lang.IllegalArgumentException: Timestamp format must be yyyy-mm-dd hh:mm:ss[.fffffffff]]]

Mysql Сведения о таблице

ID                    int(11)   NO  PRI 
flightnumber        varchar(50) NO      
operatingairlines   varchar(50) NO      
departurecity       varchar(50) NO      
arrivalcity         varchar(50) NO      
departuredate        date       NO      
departuretime        timestamp  NO      CURRENT_TIMESTAMP

1 Ответ

0 голосов
/ 19 февраля 2020

Вы можете сделать что-то вроде этого. Просто используйте Date со следующей аннотацией.

@Column(name="departuretime")
@Temporal(TemporalType.TIMESTAMP)
private Date estimatedTravelTime;
...