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