0

これが少し複雑であることは承知しており、他の方法を使用してこれを達成することもできますが、ご容赦ください。

イベントのない日付を表示できるように、日付で満たされたテーブルをイベントで満たされたテーブルに結合しようとしています。この問題を処理する QUERY を作成しましたが、特定の日付に複数のイベントがある場合、複数のレコードを結合できないようです。結合のすべてのバリエーションを試しました。

ここで私の問題を見てください

SQL コード

SELECT @RowNumber := @RowNumber + 1 AS DayNumber, D.Date, L.LessonID, L.Title 
FROM dates D 
JOIN (SELECT @RowNumber:= 0) R 
LEFT JOIN lessons L ON L.DayNumber = (@RowNumber+1) 
WHERE D.Date IN ('2012-01-01','2012-01-03','2012-01-05','2012-01-10') 
ORDER BY DayNumber ASC LIMIT 0, 50

テーブル スキーマ

CREATE TABLE IF NOT EXISTS `dates` (
  `DateID` int(11) NOT NULL AUTO_INCREMENT,
  `Date` date NOT NULL,
  `TimeStamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`DateID`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1;

INSERT INTO `dates` (`DateID`, `Date`, `TimeStamp`) VALUES
(1, '2012-01-01', '2013-02-16 17:38:07'),
(2, '2012-01-02', '2013-02-16 17:38:07'),
(3, '2012-01-03', '2013-02-16 17:38:07'),
(4, '2012-01-04', '2013-02-16 17:38:07'),
(5, '2012-01-05', '2013-02-16 17:38:07'),
(6, '2012-01-06', '2013-02-16 17:38:07'),
(7, '2012-01-07', '2013-02-16 17:38:07'),
(8, '2012-01-08', '2013-02-16 17:38:07'),
(9, '2012-01-09', '2013-02-16 17:38:07'),
(10, '2012-01-10', '2013-02-16 17:38:07');

CREATE TABLE IF NOT EXISTS `lessons` (
  `LessonID` int(11) NOT NULL AUTO_INCREMENT,
  `DayNumber` int(11) NOT NULL DEFAULT '0',
  `Title` varchar(1024) NOT NULL,
  `TimeStamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`LessonID`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1;

INSERT INTO `lessons` (`LessonID`, `DayNumber`, `Title`, `TimeStamp`) VALUES
(1, 1, 'asdfasdf', '2012-01-01 18:03:21'),
(2, 1, 'qwerqwer', '2012-01-05 18:03:21'),
(3, 3, '12341234', '2012-01-05 18:03:34');

結果

現在、これはこれを返します:

DAYNUMBER DATE  LESSONID    TITLE
1   January, 01 2012 00:00:00+0000  1   asdfasdf
2   January, 03 2012 00:00:00+0000  (null)  (null)
3   January, 05 2012 00:00:00+0000  3   12341234
4   January, 10 2012 00:00:00+0000  (null)  (null)

しかし、私はこれを返したいと思っています (DayNumber 1 の 2 行目にタイトル "qwerqwer" があることに注意してください):

DAYNUMBER   DATE    LESSONID    TITLE
1   January, 01 2012 00:00:00+0000  1   asdfasdf
1   January, 01 2012 00:00:00+0000  1   qwerqwer
2   January, 03 2012 00:00:00+0000  (null)  (null)
3   January, 05 2012 00:00:00+0000  3   12341234
4   January, 10 2012 00:00:00+0000  (null)  (null)
4

1 に答える 1

0

あなたの質問を正しく理解していれば、次のようなことができます。

SELECT T.DayNumber,
  T.Date,
  L.LessonId,
  L.Title
FROM (
  SELECT @RowNumber := @RowNumber + 1 AS DayNumber, 
    D.Date
  FROM dates D 
     JOIN (SELECT @RowNumber:= 0) R 
  WHERE D.Date IN ('2012-01-01','2012-01-03','2012-01-05','2012-01-10') 
) T LEFT JOIN Lessons L ON 
    T.DayNumber = L.DayNumber 
ORDER BY T.DayNumber ASC LIMIT 0, 50

これが更新されたFiddleです。

結果は次のとおりです。

DAYNUMBER   DATE                                LESSONID     TITLE
1           January, 01 2012 00:00:00+0000      1            asdfasdf
1           January, 01 2012 00:00:00+0000      2            qwerqwer
2           January, 03 2012 00:00:00+0000      (null)       (null)
3           January, 05 2012 00:00:00+0000      3            12341234
4           January, 10 2012 00:00:00+0000      (null)       (null)

ところで -- 上記の結果では、2 番目の結果のレッスン ID は 1 です -- 上記の結果のように、レッスン ID 2 を意味していたと思います。

于 2013-02-17T16:21:02.340 に答える