1

我有下表

ID      TYPE        Text       ImagePath     Title    Date

 1      Text        Test        NULL          NULL     14/10/2013
 2      Image       NULL        /test/test    NULL     14/10/2013
 3      Title       NULL        NULL          Test     14/10/2013
 4      Text        Test2       NULL          NULL     20/12/2012

如何仅检索最后 3 条(按日期排序)记录,1 条文本类型,1 条图像类型和 1 条仅标题类型?(基本上我只需要不为 NULL 的类型和相关字段。

4

2 回答 2

1

除了按照我在对您的问题的评论中所说的那样重组您的数据库之外,这应该会给您想要的东西(如果我正确理解了这个问题):

SELECT
TOP 1 
'Text' AS Type,
Text
FROM
your_table
ORDER BY Date DESC
UNION ALL
SELECT
TOP 1 
'ImagePath',
ImagePath
FROM
your_table
ORDER BY Date DESC
UNION ALL
SELECT
'Title', 
TOP 1 Title
FROM
your_table
ORDER BY Date DESC

您可能必须在这里和那里放置一些括号才能使其正常工作...

于 2013-10-14T15:39:21.210 回答
0

一个想法可能是:

SELECT  * FROM table where TYPE = 'Text' OFFSET 1 ROWS FETCH NEXT 1 ROWS ONLY 
union
SELECT  * FROM table where TYPE = 'Image' OFFSET 1 ROWS FETCH NEXT 1 ROWS ONLY 
union
SELECT  * FROM table where TYPE = 'Title' OFFSET 1 ROWS FETCH NEXT 1 ROWS ONLY 
于 2013-10-14T15:27:21.467 回答