首頁 > 資料庫 > mysql教程 > Oracle函数之case和decode的用法区别及性能比较

Oracle函数之case和decode的用法区别及性能比较

WBOY
發布: 2016-06-07 17:17:47
原創
1758 人瀏覽過

Oracle函数之case和decode的用法区别及性能比较,来实现逻辑判断。Oracle的DECODE函数功能很强,灵活运用的话可以避免多次扫描,从

在Oracle世界,你可以使用:

1)case表达式      或者

2)decode函数

来实现逻辑判断。Oracle的DECODE函数功能很强,灵活运用的话可以避免多次扫描,从而提高查询的性能。而CASE是9i以后提供的语法,这个语法更加的灵活,提供了IF THEN ELSE的功能。

case表达式

case表达式,可分两种,简单和搜索,简单case后接表达式,如:

Oracle函数之case和decode的用法区别及性能比较

对于简单的case需要几点注意:

1)寻找when的优先级:从上到下

2)再多的when,也只有一个出口,即其中有一个满足了expr就马上退出case

3)不能把return_expr和else_expr指定为null,而且,,expr、comparison_expr和return_expr的数据类型必须相同。

Oracle函数之case和decode的用法区别及性能比较

搜索case:

CASE WHEN condition THEN return_expr

[WHEN condition THEN return_expr]

...

ELSE else_expr

END

例子:

用decode可以违反第3NF(行不可再分,列不可再分,列不可重复):列重复

linux

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板