이렇게 생긴 테이블이 두 개 있어요
기차
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| TrainID | varchar(11) | NO | PRI | NULL | |
| Capacity | int(11) | NO | | 50 | |
+----------+-------------+------+-----+---------+-------+
전세
+---------------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+---------------+-------------+------+-----+---------+----------------+
| ReservationID | int(11) | NO | PRI | NULL | auto_increment |
| FirstName | varchar(30) | NO | | NULL | |
| LastName | varchar(30) | NO | | NULL | |
| DDate | date | NO | | NULL | |
| NoSeats | int(2) | NO | | NULL | |
| Route | varchar(11) | NO | | NULL | |
| Train | varchar(11) | NO | | NULL | |
+---------------+-------------+------+-----+---------+----------------+
현재 예약이 취소되면 열차의 용량을 증가시키는 쿼리를 생성하려고합니다. 조인을 수행해야한다는 것을 알고 있지만 Update 문에서 수행하는 방법을 잘 모르겠습니다. 예를 들어 특정 ReservationID를 사용하여 열차의 용량을 얻는 방법을 알고 있습니다.
select Capacity
from Train
Join Reservations on Train.TrainID = Reservations.Train
where ReservationID = "15";
하지만이 작업을 수행하는 쿼리를 구성하고 싶습니다.
Increment Train.Capacity by ReservationTable.NoSeats given a ReservationID
가능하다면 임의의 좌석 수만큼 증가시키는 방법도 알고 싶습니다. 제쳐두고 Java 트랜잭션에서 증분을 수행 한 후 예약을 삭제할 계획입니다. 삭제가 거래에 영향을 줍니까?
도와 주셔서 감사합니다!