我有三个具有以下结构的表:-
CREATE TABLE `contract` (
  `conid` int(11) NOT NULL AUTO_INCREMENT,
  `servName` int(11) NOT NULL,
  `cid` int(11) NOT NULL,
  `term` int(11) DEFAULT NULL,
  `monthly_charge` double NOT NULL,
  `start_date` date NOT NULL,
  `expiry_Date` date NOT NULL,
  `next_PayDate` date DEFAULT NULL,
  `status` tinyint(4) NOT NULL,
  PRIMARY KEY (`conid`),
  UNIQUE KEY `servName` (`servName`,`cid`)
) 
CREATE TABLE `servicetype` (
  `sid` int(11) NOT NULL AUTO_INCREMENT,
  `serviceName` varchar(255) NOT NULL,
  PRIMARY KEY (`sid`)
) 
CREATE TABLE `transactions` (
  `tid` int(11) NOT NULL AUTO_INCREMENT,
  `conid` int(11) NOT NULL,
  `amount` double NOT NULL,
  `paidate` date NOT NULL,
  `descr` text NOT NULL,
  PRIMARY KEY (`tid`)
)
我想要得到的是特定用户的最新交易,即:-
conid、serviceName、cid、term、monthly_charge、start_date、expiry_Date、next_PayDate、金额、payate、descr
这是我使用获取该信息的选择语句:-
SELECT c.conid, serviceName, cid, term, monthly_charge, start_date, expiry_Date, next_PayDate, status, amount, paidate, descr
FROM servicetype s 
LEFT JOIN contract c on s.sid = c.servName 
LEFT JOIN transactions t ON c.conid=t.conid
WHERE cid = 4 AND status = 1
该声明有效,但是它给了我属于 cid 4 的所有交易,而我只想显示属于该合约的最新交易(conid)。
提前感谢您的时间和精力。