10-oracle_表达式

1) 关系表达式 >,<,>=

在我们做查询语句时,经常会在 where 后面加上关系表达式。返回逻辑为 TRUE 的记录。

select * from t_sales a where a.sales_amt > 5000 ;

所以结果只返回了销售额大于 5000 的记录 3

 

2) 逻辑表达式 and,or,not

select *

  from t_sales a

  where a.sales_amt > 5000

   and a.dept_code = 'B' ;

因为 and 是要求 2 个条件都成立,销售额大于 5000 并且部门为 B 的记录,所以只返回了 2 条记录。在上一个查询返回的 3 条记录里,有一条部门信息是 A ,就被过滤掉了。

 

3) 条件表达式 case,decode

CASE 语法:

case

  when 列值 1 then   显示值 1

  when 列值 2 then   显示值 2

  when 列值 3 then   显示值 3

else

  默认值

end

 

DECODE 语法:

decode ( , 列值 1, 显示值 1, 列值 2, 显示值 2, 默认值 )

2 个语法都能实现条件的转换,不过 case decode 的应用更灵活, decode 只能按列表形式转换,在 decode_col 这列中,列值与显示值只能一一对应关系,不能像 case_col2 列这样,对某一个范围值映射到一个显示值。对于销售额在 5000 以下的我想显示不合格,如果用 decode 来做无法实现,这也是他们 2 个语法的不同点,在应用中我们更喜欢用 case ,一个这是 SQL 的标准语法,其他数据库都支持,另一个是更好的理解性,很容易理解逻辑,还有就是他比 decode 更灵活,能实现 decode 所有功能。

 

4)between

Between 类似于 >= and <= 合在一起的效果,在对于字段是数字、字符、日期等类型时,都是左右全闭区间。

select * from t_sales a where a.sales_amt between 4563 and 6794 ;

select * from t_sales a where a.user_no between '002' and '004' ;

在第一个查询里按数字类型把销售额为 4563 6794 的记录返回结果集了,表示一个全闭区间,第二个查询按字符类型把 002 004 用户返回了,也表示一个全闭区间。



来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31535951/viewspace-2641329/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31535951/viewspace-2641329/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值