一道sql面试题的解答

来源:互联网 发布:mac定制无瑕粉底液实测 编辑:程序博客网 时间:2024/04/29 21:30

一道sql面试题的解答

题目:

  写出一条Sql语句:

    取出表A中第31到第40记录(SQLServer, 以自动增长的ID作为主键,  注意:ID可能不是连续的。)

 

解答(已测试):

  1、假设ID是连续的:

    select top10 *fromAwhereIDnot in(selecttop30 IDfromA)

  或

    select  *  fromAwhereIDbetween31and40

 

  2、假设ID是不连续的:

    select top40 *fromAexceptselecttop30 *fromA

  或

    select top10 *fromAwhereID > (selectmax(ID)fromAwhereIDin(select top30 IDfromA))

     或

    select top10 *fromAwhereIDnot in(selecttop30 IDfromA) 

原创粉丝点击