oracle笔记(二) 过滤与排序

过滤与排序

 

1、过滤:通过条件,把需要的结果返回。

     1.where关键字

      2.字符串匹配

               1)要用单引号。

               2)字符串大小写敏感,日期格式敏感。说明:如果匹配字符串中写错大小写,那么查不到你想要的数据,where name=‘zhang’和 where name='ZHANG'所返回的结果不同。同样,对于日期格式,如果格式与表中对应列的日期格式不同,那么直接报错。Oracle数据库中,默认日期格式 DD-MON-RR  该格式为9i之后的格式,9i之前格式为  DD-MON-YY 9i之后,如果过50年就算下个世纪,没过就算上个世纪。判断日期格式的方式可以查询当前系统时间 select sysdate from dual  第二种方式 :查询系统参数  select * from v$nls_parameters

         其中 v$nls_parameters 系统提供的数据字典。

2、修改日期格式   alter session|global set NLS_DATE_FORMAT='yyyy-mm-dd'如果是要修改全局的,那必须是管理员账户。

3、比较运算

     1) 不等于:<>  或者 !=

     2) is null与空值相比  is not null

     3)in(set)在set中 not in 不在set中  如果集合中含有null那么不能使用not in操作符,但是可以使用 in操作符,因为not in做的是与操作所以就得不到任何结果(null!=null),而in 做的是或操作。

     4)between  ... and  ...需注意:包含边界,小值在前,大值在后,否则报错,日期也是一样的。

      5)like模糊查询  %表示任意长度的任意字符串  _表示任意一个字符。如果需要查找的字符串中含有_  % 则需要用转义字符  例如select * from emp where ename like '%\_%' escape '\' 表示忽略‘\’ 号后面的一个字符。

4、commit  rollback Oracle自动开启事务mysql手动开启。

5、SQL优化:and or 类似于编程语言中的短路与和短路或,oracle解析where条件时,顺序是从右到左,所以and中的为假的应该放在右边,or中为真的放在右边。

6、排序

   1) 默认是升序

    2) order by  关键字

     3)a命令意思是append 

    4)a中间两个或两个以上的空格 desc

    5)order by 后面可以跟 列名、表达式、别名、序号(下标从1开始)

    6)order by 后面可以跟多列,比较的时候如果第一列相同,则比较第二列,以此类推。需要注意,降序DESC作用于离它最近的一列,如果需要作用于多列,可以在没列后面加DESC 例如ename desc,empno desc

     7)set pagesize 40,如果排序列中包含null,那么null值在升序中无限大,降序中也是表示无限大,如果需要在降序中把null值表示在最后,那么需要在最后加  nulls last语句,这样就把null排到最后了。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值