我有一张桌子Orders
Name DateOrdered
louie 01/50/2017
jonathan 02/06/2016
prince 05/23/2016
louie 07/02/2016我想按年份选择记录,例如2016年,但我希望结果只显示jonathan和prince,因为louie有2017年的最新记录,如何查询?提前谢谢。
发布于 2017-10-10 11:38:26
尝试下面的示例查询。
SELECT * from Orders WHERE YEAR(DateOrdered) = '2016' AND name !=
'louie';发布于 2017-10-10 10:36:19
With子查询。例如,在transact sql ( sybase ase)中
Select from orders a
Where DateOrdered != (select min(dateordered) from orders b
where convert(char(04),dateordered)=convert(char(04),a.dateordered))convert函数用于比较字段dateordered中的年份部分
我希望它能对你有所帮助。
发布于 2017-10-10 11:05:43
如果使用下面的日期对查询进行排序,则查询可以删除顶行:
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列中提取年份
https://stackoverflow.com/questions/46657690
复制相似问题