首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >按日期选择行并排除具有最新记录的行

按日期选择行并排除具有最新记录的行
EN

Stack Overflow用户
提问于 2017-10-10 10:15:42
回答 3查看 185关注 0票数 1

我有一张桌子Orders

代码语言:javascript
运行
复制
Name             DateOrdered
louie            01/50/2017
jonathan         02/06/2016
prince           05/23/2016
louie            07/02/2016

我想按年份选择记录,例如2016年,但我希望结果只显示jonathanprince,因为louie有2017年的最新记录,如何查询?提前谢谢。

EN

回答 3

Stack Overflow用户

发布于 2017-10-10 11:38:26

尝试下面的示例查询。

代码语言:javascript
运行
复制
 SELECT * from Orders WHERE YEAR(DateOrdered) = '2016' AND name != 
'louie';
票数 2
EN

Stack Overflow用户

发布于 2017-10-10 10:36:19

With子查询。例如,在transact sql ( sybase ase)中

代码语言:javascript
运行
复制
Select from orders a
Where DateOrdered  != (select min(dateordered) from orders b 
                       where convert(char(04),dateordered)=convert(char(04),a.dateordered))

convert函数用于比较字段dateordered中的年份部分

我希望它能对你有所帮助。

票数 0
EN

Stack Overflow用户

发布于 2017-10-10 11:05:43

如果使用下面的日期对查询进行排序,则查询可以删除顶行:

代码语言:javascript
运行
复制
declare @Total INT;
declare @requiredRows INT;
Select @Total=  Count (*) From Orders
SET @requiredRows = @Total -1;

Select * From(
Select TOP (@requiredRows) * From Orders
Order By DateOrdered ASC) As tbl
Order By DateOrdered DESC

您可以使用' year‘函数从dateOrdered列中提取年份

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46657690

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档