过滤与排序
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排到最后了。
|