Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 1664|回复: 0

今天面试碰到了一个SQL题目,不知道怎么搞

  [复制链接]

该用户从未签到

发表于 2011-10-30 08:39:19 | 显示全部楼层 |阅读模式
就是查询表A中第35到41的记录
回复

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:20 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

SQL code selet * from a where id between 35 and 41
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:21 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

SQL code select * from a where id between 35 and 41
--面试的人没有说有没有ID啊?或者其他的信息?
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:22 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

SQL 还是Oracle
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:23 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

他说ID可能不是连续的,这有关系吗
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:25 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

SQL code 取n到m行

1.
select top (n-m+1) * from tablename where id not in (select top n id from tablename order by id asc/*|desc*/)

2.
select top m * into 临时表(或表变量) from tablename order by columnname -- 将top m笔插入到临时表
set rowcount n   --只取n条结果
select * from 表变量 order by columnname desc

3.
select top n * from  
(select top m * from tablename order by columnname) a
order by columnname desc


4.如果tablename里没有其他identity列,那么:
先生成一个序列,存储在一临时表中.
select identity(int) id0,* into #temp from tablename

取n到m条的语句为:
select * from #temp where id0 > =n and id0  <= m

如果你在执行select identity(int) id0,* into #temp from tablename这条语句的时候报错,那是因为你的DB中间的select into/bulkcopy属性没有打开要先执行:
exec sp_dboption 你的DB名字,'select into/bulkcopy',true


5.如果表里有identity属性,那么简单:
select * from tablename where identity_col between n and m  

6.SQL2005开始.可以使用row_number() over()生成行号
;with cte as
(
select id0=row_number() over(order by id),* from tablename
)
select * from cte where id0 between n to m
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:26 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

SQL code
/*
id          name       row
----------- ---------- --------------------
35          A35        35
36          A36        36
37          A37        37
38          A38        38
39          A39        39
40          A40        40
41          A41        41

(7 行受影响)
*/
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:27 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

SQL code
select * from (select *,row_number() over(order by id) num from tb) a where num<41 and num>35
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:28 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

SQL code select top 7 * from A where ID not in(select top 34 ID from A order by ID) order by ID
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-30 08:39:29 | 显示全部楼层

Re:今天面试碰到了一个SQL题目,不知道怎么

SQL code select * from (select top 41 * from A) a left join (select top 34 8 from A) b on a.xx=b.xx where b.xx is null
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2024-12-23 09:15 , Processed in 0.956424 second(s), 33 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表