这样的查询语句怎么写(SQL Server 2008)
我有这样的一个表,我希望可以写一条语句查询出处于“上升“状态时第一个数值大于0的点,即查询后得到序号3和序号12.请问这样的查询语句怎么写,希望指点一二。...
我有这样的一个表,我希望可以写一条语句查询出处于“上升“状态时第一个数值大于0的点,即查询后得到序号3和序号12.请问这样的查询语句怎么写,希望指点一二。
展开
展开全部
用这个语句,必能缺高达到你想要的效果蚂正,将字段名换一下,ID-序号,state-状态,num-数值,test-表名
select * from test where state='闷扮悔上升' and num>0 and rownum=1
union all
select b.id,b.state,b.num from
(select row_number() over(order by id) rn, id,state,num from test a where state='上升' and num>0) a inner join
(select row_number() over(order by id) rn,id,state,num from test a where state='上升' and num>0) b on a.rn+1=b.rn
where b.id<>a.id+1
select * from test where state='闷扮悔上升' and num>0 and rownum=1
union all
select b.id,b.state,b.num from
(select row_number() over(order by id) rn, id,state,num from test a where state='上升' and num>0) a inner join
(select row_number() over(order by id) rn,id,state,num from test a where state='上升' and num>0) b on a.rn+1=b.rn
where b.id<>a.id+1
追问
我运行以上代码为什么得不到合理的结果?另外第一行的 rownum=1这个字段不存在,将 rownum替换为rn也不存在。
追答
哦,忘记了,因为我那个语句是在ORALLE下运行的,在SQLSERVER 中第一句要改成
select top 1 t.* from test t where state='上升' and num>0
另外我电脑没装sqlserver,我晚点给你回复,原理是差不多的
展开全部
select * from 表 where 状态=‘上升’ and 数值 >0
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
其实挺简单啊,就是语言的转化而已,自然语孝橡盯言转化成SQL语句
select 序号 from 表 where 状态='上升' and 数值>0
要自己去尝试写,然后执行看看如睁结果对不对,慢慢调整直到对为止,巧和加油,年轻人!
爱云一万年
select 序号 from 表 where 状态='上升' and 数值>0
要自己去尝试写,然后执行看看如睁结果对不对,慢慢调整直到对为止,巧和加油,年轻人!
爱云一万年
追问
你没有理解我的意思,我只要处于上升状态的第一个大于0的点,你给我的查询会查出处于上升状态所有的大于0的点
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用下面的语句试答尘试。
select xuhao from tablename where num>0
或者
select xuhao 燃举带from tablename where state='皮芦上升' and num>0
更多追问追答
追问
你没有理解我的意思,我只要处于上升状态的第一个大于0的点,你给我的查询会查出处于上升状态所有的大于0的点
追答
查询第一个的语句
mysql
select xuhao from tablename where state='上升' and num>0 limit 1
sqlserver
select top 1 xuhao from tablename where state='上升' and num>0
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询