DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: laidabin
今日帖子: 3
在线用户: 28
导航: 论坛 -> 数据库专区 斑竹:liumazi,waterstone  
作者:
男 ltxubo (波仔) ★☆☆☆☆ -
普通会员
2019/4/26 15:35:50
标题:
棘手的数据库问题 浏览:1335
加入我的收藏
楼主: 想求出一个按时间顺序的第一个值和最后一个值,还真没想出一个好的方法,都是笨拙的方法,看看群里有没有高手提点一下.原来的方法,感觉笨,
select * from(select top 1 * from table order by 日期desc)
          union 
          (select top 1 * from table order by 日期 asc);

谁有更好的方法?
----------------------------------------------
-
作者:
男 liuzemin (liuzemin) ★☆☆☆☆ -
普通会员
2019/4/26 15:40:13
1楼: 这办法看起来不错呀,传输量小,计算放在服务器端。
----------------------------------------------
-
作者:
男 ltxubo (波仔) ★☆☆☆☆ -
普通会员
2019/4/26 15:44:50
2楼: 想找个更简洁优雅的
----------------------------------------------
-
作者:
男 a5824 (Return) ★☆☆☆☆ -
普通会员
2019/4/26 15:49:01
3楼: SELECT MIN(日期) AS minDate,Max(日期) as maxData FROM table
----------------------------------------------
-
作者:
男 ltxubo (波仔) ★☆☆☆☆ -
普通会员
2019/4/26 15:51:56
4楼: 求的是值,不是日期
----------------------------------------------
-
作者:
男 a5824 (Return) ★☆☆☆☆ -
普通会员
2019/4/26 17:08:36
5楼: SELECT * FROM (
SELECT  ROW_NUMBER( ) OVER (ORDER BY 日期) AS id,ROW_NUMBER( ) OVER (ORDER BY 日期 DESC) AS idd,* FROM table
) A 
WHERE A.id=1 OR A.idd=1

那就这样了,看看快不快了
----------------------------------------------
-
作者:
男 luckyrandom (luckyrandom) ★☆☆☆☆ -
普通会员
2019/4/28 9:16:03
6楼: 对 日期 加个索引,两种写法都快
----------------------------------------------
SQL SERVER DBA QQ:315054403 曾经的Delphier  缘在上海
作者:
男 hdcopy (hdcopy) ★☆☆☆☆ -
普通会员
2019/4/28 9:57:24
7楼: 当sqlserver遇到oracle
----------------------------------------------
-
作者:
男 ltxubo (波仔) ★☆☆☆☆ -
普通会员
2019/4/28 12:56:05
8楼: @Return 你的方法速度挺快的,但是我想要的结果是:
select 值1 as 第一个数据,值2 as 最后一个数据,max(值) as 最大数值 from table 
这已经不错了,非常感谢!
----------------------------------------------
-
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行66.40625毫秒 RSS