zoukankan      html  css  js  c++  java
  • Sql Server2008温故而知新系列06:查询-分页和排序查询

    说到分页就不得不提Mysql的limit了,感觉比sql server要简便一些;如果要在sql server2008中实现Limit的话,可以使用子查询;

    sql server中的分页(假设说法)关键词是top,通常和order by(排序)一起使用;如果不排序,查询得到的可能并不是自己想要的结果。

    先说一下正序与逆序排序

    如:

     1 --查询在男职员工eid,hida;以hida顺序排序
     2 select eid,hida 
     3     from emp 
     4     where flag=1 and sex=''
     5     order by hida 
     6 -- 逆序
     7 select eid,hida
     8     from emp
     9     where flag=1 and sex=''
    10     order by hida desc

     顺序是 asc,默认可以省略,逆序是desc(不可以省略),直接加在排序的每一个字段后面。

    那么如果只想查询前3个,怎么办呢。直接在查询的时候加上top就可以了;

    如:

     1 --查询在男职员工eid,hida;以hida顺序排序前3位 top (表达式)
     2 select top (3) eid,hida 
     3     from emp 
     4     where flag=1 and sex=''
     5     order by hida 
     6 -- 逆序前3位
     7 select top (4-1) eid,hida
     8     from emp
     9     where flag=1 and sex=''
    10     order by hida desc

    注意: top后面可以加表达式(可以是计算列)

    那如果我们需要以顺序排列的第2条记录,或者以顺序排列的2-4这3行记录呢?

    这个就需要系列07(子查询)的帮助了

    --Ocarina我是一只可爱的小尾巴
  • 相关阅读:
    Privacy Policy
    privacy
    将一个无法一次读入内存的大文件排序
    java实现二叉树的非递归遍历
    java静态方法同步问题
    关于java静态方法继承问题
    Android 代码写布局
    Android自定义ImageView实现手势放大图片的控件,无需依赖任何第三方。
    Gradle版本更换问题
    Android的AlertDialog实现圆角边框
  • 原文地址:https://www.cnblogs.com/azrealer/p/11857467.html
Copyright © 2011-2022 走看看