航空機の名前(aircraft_type)、個々の航空機の時間の合計(aircraft_masterのフラグA)、個々の航空機に支払われた料金の合計(料金表のac_id)を取得する必要があります
クエリを使用する
select
t1.aircraft_type,
sec_to_time(sum(time_to_sec(t2.ft_duration))),
sum(t3.fee_amount)
from
aircraft_master t1
left join flying_test t2 on t2.ac_id = t1.ac_id
left join fees_detail t3 on t3.ac_id = t1.ac_id
where
t2.per_detail_id = '12'
and t3.per_detail_id = '12'
group by
t1.ac_id]
fly_testに参加しなくても、正しい飛行時間が得られます。有料で参加することなく、私は個々の航空機に支払われる正しい金額を受け取ります。両方を使用すると、時間と料金の倍数が得られます。
SQLテーブルとデータ:
-- phpMyAdmin SQL Dump
-- version 3.4.5
-- http://www.phpmyadmin.net
--
-- Host: localhost
-- Generation Time: Jul 11, 2012 at 11:07 PM
-- Server version: 5.5.16
-- PHP Version: 5.3.8
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
--
-- Database: `aviation`
--
-- --------------------------------------------------------
--
-- Table structure for table `aircraft_master`
--
CREATE TABLE IF NOT EXISTS `aircraft_master` (
`ac_id` int(10) NOT NULL AUTO_INCREMENT,
`aircraft_type` varchar(50) DEFAULT NULL,
`aircraft_engine` varchar(150) DEFAULT NULL,
`flag` varchar(1) DEFAULT NULL,
PRIMARY KEY (`ac_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=22 ;
--
-- Dumping data for table `aircraft_master`
--
INSERT INTO `aircraft_master` (`ac_id`, `aircraft_type`, `aircraft_engine`, `flag`) VALUES
(1, NULL, 'Single Engine', 'E'),
(2, NULL, 'Multi Engine', 'E'),
(3, 'CH2T', '1', 'A'),
(4, 'C172', '1', 'A'),
(5, 'C152', '1', 'A'),
(6, 'VT-SMT', '3', 'R'),
(7, 'VT-MDU', '3', 'R'),
(8, 'VT-RIT', '3', 'R'),
(9, 'VT-AFA', '4', 'R'),
(10, 'VT-TSM', '4', 'R'),
(11, 'VT-AFR', '4', 'R'),
(12, 'VT-RRM', '4', 'R'),
(13, 'VT-JSN', '4', 'R'),
(14, 'VT-AKN', '5', 'R'),
(15, 'VT-PBA', '5', 'R'),
(16, 'VT-AKA', '5', 'R'),
(17, 'VT-AFN', '5', 'R'),
(18, 'VT-AFN', '5', 'R'),
(19, 'VT-EMO', '5', 'R'),
(20, 'VT-EMP', '5', 'R'),
(21, 'VT-RJT', '3', 'R');
-- --------------------------------------------------------
--
-- Table structure for table `fees_detail`
--
CREATE TABLE IF NOT EXISTS `fees_detail` (
`fee_id` int(11) NOT NULL AUTO_INCREMENT,
`per_detail_id` int(10) NOT NULL,
`fee_detail_id` varchar(10) NOT NULL,
`fee_date` date DEFAULT NULL,
`mode_id` int(11) DEFAULT NULL,
`fee_amount` int(10) DEFAULT NULL,
`bank_id` int(20) DEFAULT NULL,
`bank_branch` varchar(100) DEFAULT NULL,
`chqdd_no` int(20) DEFAULT NULL,
`fee_comment` varchar(150) DEFAULT NULL,
`fee_posting_time` datetime NOT NULL,
`ac_id` int(10) DEFAULT NULL,
PRIMARY KEY (`fee_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=19 ;
--
-- Dumping data for table `fees_detail`
--
INSERT INTO `fees_detail` (`fee_id`, `per_detail_id`, `fee_detail_id`, `fee_date`, `mode_id`, `fee_amount`, `bank_id`, `bank_branch`, `chqdd_no`, `fee_comment`, `fee_posting_time`, `ac_id`) VALUES
(16, 12, '9', '2012-06-13', 87, 70000, NULL, NULL, NULL, 'c172', '2012-06-16 17:20:34', 4),
(17, 12, '10', NULL, NULL, 10000, NULL, NULL, NULL, NULL, '0000-00-00 00:00:00', 3),
(18, 12, '10', NULL, NULL, 10000, NULL, NULL, NULL, NULL, '2012-07-10 12:00:05', 3);
-- --------------------------------------------------------
--
-- Table structure for table `flying_test`
--
CREATE TABLE IF NOT EXISTS `flying_test` (
`ft_id` int(10) NOT NULL AUTO_INCREMENT,
`ft_from` varchar(10) DEFAULT NULL,
`ft_from_time` time DEFAULT NULL,
`ft_to` varchar(10) DEFAULT NULL,
`ft_to_time` time DEFAULT NULL,
`ft_pic` varchar(50) DEFAULT NULL,
`ft_engine` varchar(10) DEFAULT NULL,
`per_detail_id` int(10) NOT NULL,
`ft_remark` varchar(512) DEFAULT NULL,
`ft_type` int(3) DEFAULT NULL,
`ft_ftftpr` int(10) DEFAULT NULL,
`ft_nature_exercise` int(3) DEFAULT NULL,
`ftpr_ut` varchar(150) DEFAULT NULL,
`ftpr_co_pilot` varchar(150) DEFAULT NULL,
`ftpr_pi_us` varchar(150) DEFAULT NULL,
`ft_status` int(3) DEFAULT NULL,
`ft_aircraft` int(5) DEFAULT NULL,
`ft_regno` int(3) DEFAULT NULL,
`ft_landings` int(3) DEFAULT NULL,
`ft_duration` time DEFAULT NULL,
`fee_detail_id` int(10) DEFAULT NULL,
`ft_act` time DEFAULT NULL,
`ft_sim` time DEFAULT NULL,
`ft_simulator` time DEFAULT NULL,
`ft_dh` int(3) DEFAULT NULL,
`ft_exercise` int(3) DEFAULT NULL,
`ft_date` date DEFAULT NULL,
PRIMARY KEY (`ft_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=83 ;
--
-- Dumping data for table `flying_test`
--
INSERT INTO `flying_test` (`ft_id`, `ft_from`, `ft_from_time`, `ft_to`, `ft_to_time`, `ft_pic`, `ft_engine`, `per_detail_id`, `ft_remark`, `ft_type`, `ft_ftftpr`, `ft_nature_exercise`, `ftpr_ut`, `ftpr_co_pilot`, `ftpr_pi_us`, `ft_status`, `ft_aircraft`, `ft_regno`, `ft_landings`, `ft_duration`, `fee_detail_id`, `ft_act`, `ft_sim`, `ft_simulator`, `ft_dh`, `ft_exercise`, `ft_date`) VALUES
(79, 'VISL', '10:00:00', 'VISL', '23:00:00', 'vcvc', '1', 12, 'dss', NULL, 16, 101, NULL, NULL, NULL, 20, 3, 8, 1, '15:30:00', 10, '00:00:00', '00:00:00', '00:00:00', 18, 38, '2012-07-07'),
(80, NULL, NULL, NULL, NULL, NULL, NULL, 12, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 4, NULL, NULL, '02:30:00', 9, NULL, NULL, NULL, NULL, NULL, '2012-07-25'),
(81, NULL, NULL, NULL, NULL, NULL, NULL, 12, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 3, NULL, NULL, '02:30:00', 10, NULL, NULL, NULL, NULL, NULL, '2012-07-25'),
(82, 'VISL', '15:30:00', 'VISL', '15:45:00', 'none', '1', 12, 'none', NULL, 16, 100, NULL, NULL, NULL, 20, 3, 6, 1, '00:15:00', NULL, '00:00:00', '00:00:00', '00:00:00', 18, 38, '2012-07-11');
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;