oracle的between...and..

今天下午上班没事,就把oracle的sql手册找出来,一一做了一下,才发现对rang condition(范围条件),between..and..的理解一直是错误的,现简单地总结(都不好意思说,太简单了,但不注意可能会在生产环境中造成错误).

   1)sql中的conditions是在select,delete,update语句常常用到的,其中range condition只包含:(not)between..and.

  2)oracle的between..and..前后都是闭区间,也就是说包含两个端的数,例如:

SELECT * FROM employees
  WHERE salary
  BETWEEN 2000 AND 3000;
查询返回 2000<=工资<=3000的员工

    3)当前者数大于后者,如:salary between 100 and 10;此时不会出错,但salary为50的记录也不能被取出。

    4)not between..and..只是取指定范围的相反范围,也就是不在这个范围的记录,其用户可以用组个逻辑条件来取代。

你可能感兴趣的:(oracle,sql)