oracle中使用sql查詢時字段為空則賦值默認

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。

?oracle 通過 nvl( )函數sql 查詢時為 空值 賦默認值

oracle 函數介紹之nvl

?

  函數聲明:nvl(col,val)

  說明:當col為空時取val作為返回值,當col不為空時取col值。

  用處:最主要的是格式化數據,比如計算金額時,不想出現空數據,可以使用nvl(JINE,0)來得到0。由于null+(或-,*,/)數字等于null,所以在表達式中對可能為空的值要使用nvl由于null!=null,有時對可能為空的列進行條件查詢時,可能出現結果集丟失數據問題,加上nvl就不會了。

?

經典用法:

通過查詢獲得某個字段的合計值,如果這個值為null將給出一個預設的默認值
例如:
select nvl(sum(t.字段),1) ?from table t
就表示如果sum(t.字段) = NULL 就返回 1
另一個有關的有用方法
declare i integer
select nvl(sum(t.字段),1) into i from table t?這樣就可以把獲得的合計值存儲到變量i中,如果查詢的值為null就把它的值設置為默認的1
orcale中:
select nvl(rulescore,0) from zwjc_graderule where rulecode='FWTD';?如果記錄中不存在rulecode ='FWTD'的數據.則查不出數據.
select nvl(rulescore,0) into rule_score from zwjc_graderule where rulecode='FWTD';會報查不到數據的錯
select nvl(sum(rulescore),0) from zwjc_graderule where rulecode='FWTD';?如果記錄中不存在rulecode ='FWTD'的數據.還是可以得到一行列名為nvl(rulescore,0),值為0的數據.
select nvl(sum(rulescore),0) into rule_score from zwjc_graderule where rulecode='FWTD'; 不會報錯

?

?

?

oracle 函數介紹之nvl2

Oracle在NVL函數的功能上擴展,提供了NVL2函數。
NVL2(E1, E2, E3)的功能為:如果E1為NULL,則函數返回E3,否則返回E2。E2和E3類型不同的話,E3會轉換為E2的類型。

?

?

?限制: 1)?E1可以是任意類型,E2,E3不能是long類型。
?????? 2) 如果 E2是字符類型,那么E3轉為字符型再比較(null除外)。
?????? 3) 如果 E2是數值類型,那么E3也轉為對應的數值類型。
?????? 4) 各個參數都不能是邏輯表達式.

oracle 函數介紹之nullif

格式: nullif(expr1,expr2)? 等價于 "case when expr1 = expr 2 then null else expr1 end",相等返回NULL,不等返回expr1.
限制: expr1不能是標識符null,錄入nullif(null,expr2)那么會提示錯誤。
?????????? expr1,expr2 都必須是一個變量或者是一個常量表達式,不能是邏輯表達式。

?

?

?

?

oracle 函數介紹之lnnvl(a)?

?

?

?

a是一個表達式
lnnvl只能用于where子句中;表達式的操作符號不能包含 AND, OR,? BETWEEN。
如果a的結果是false或者是unknown,那么lnnvl返回true;如果a的結果是true,返回false.
"如果a的結果是false或者是unknown,那么lnnvl返回true",這個很重要,因為一個空值或者unknown的值和另外一個常量或者有值的變量比較的時候,返回的總是unknown,所以
lnnvl(a>10)? 等價于? nvl(a,0)<=10??? 等價于? a<=10 or a is null? (假設a number(10))
說白了,lnnvl是一種特定的用于簡化表達式的函數,orcle解析的時候,應該會解析為 "a<=10 or a is null".??

?

?

oracle 函數介紹之decode()

decode()函數簡介:

主要作用:將查詢結果翻譯成其他值(即以其他形式表現出來,以下舉例說明);

使用方法:

Select decode(columnname,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)

From talbename

Where …

其中columnname為要選擇的table中所定義的column,

·含義解釋:

decode(條件,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)的理解如下:

if (條件==值1)

?then    

return(翻譯值1)

elsif (條件==值2)

then    

return(翻譯值2)    

......

elsif (條件==值n)

?then    

return(翻譯值n)

else    

return(缺省值)

end if

注:其中缺省值可以是你要選擇的column name 本身,也可以是你想定義的其他值,比如Other等;

舉例說明:

現定義一table名為output,其中定義兩個column分別為monthid(var型)和sale(number型),若sale值=1000時翻譯為D,=2000時翻譯為C,=3000時翻譯為B,=4000時翻譯為A,如是其他值則翻譯為Other;

SQL如下:

Select monthid , decode (sale,1000,'D',2000,'C',3000,'B',4000,'A',’Other’) sale from output

特殊情況:

若只與一個值進行比較

Select monthid ,decode(sale, NULL,‘---’,sale) sale from output

另:decode中可使用其他函數,如nvl函數或sign()函數等;

NVL(EXPR1,EXPR2)

若EXPR1是NULL,則返回EXPR2,否則返回EXPR1.

SELECT NAME,NVL(TO_CHAR(COMM),'NOT APPLICATION') FROM TABLE1;

如果用到decode函數中就是

select monthid,decode(nvl(sale,6000),6000,'NG','OK') from output

?

sign()函數根據某個值是0、正數還是負數,分別返回0、1、-1,

如果取較小值就是

select monthid,decode(sign(sale-6000),-1,sale,6000) from output,即達到取較小值的目的。

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/451654.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/451654.shtml
英文地址,請注明出處:http://en.pswp.cn/news/451654.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

BZOJ3040:最短路——題解

https://www.lydsy.com/JudgeOnline/problem.php?id3040 題意rt&#xff0c;使用pb_ds的堆解決本問題。 所以其實就是mark一下的。 不過有人確認過官方不能使用“using namespace __gnu_pbds;” #include<cmath> #include<queue> #include<cstdio> #include…

39--打印從1到最大的n位數

1.題目描述 輸入數字 n&#xff0c;按順序打印出從 1 到最大的 n 位十進制數。比如輸入 3&#xff0c;則打印出 1、2、3 一直到最大的 3 位數 999。 示例 1: 輸入: n 1 輸出: [1,2,3,4,5,6,7,8,9] 2.解題思路 class Solution {public int[] printNumbers(int n) {int end …

六.dbms_session(提供了使用PL/SQL實現ALTER SESSION命令)

1、概述 作用:提供了使用PL/SQL實現ALTER SESSION命令,SET ROLE命令和其他會話信息的方法 .2、包的組成 1&#xff09;、set_identifier說明&#xff1a;用于設置會話的客戶ID號。語法&#xff1a;dbms_session.set_identifier(client_id varchar2);其中client_id指定當前會話的…

多線程官方教程

多線程編程指南Sun Microsystems, Inc.4150 Network CircleSanta Clara, CA95054U.S.A.文件號碼819–7051–102006 年10 月版權所有2005 Sun Microsystems, Inc. 4150 Network Circle, Santa Clara, CA95054 U.S.A. 保留所有權利。本文檔及其相關產品的使用、復制、分發和反編譯…

iOS面試題(三)

1、Objective-C 中創建線程的方法是什么&#xff1f;如果在主線程中執行代碼&#xff0c;方法是什么&#xff1f;如果想延時執行代碼、方法又是什么&#xff1f; 線程創建有三種方法&#xff1a;使用NSThread創建、使用GCD的dispatch、使用子類化的NSOperation,然后將其加入NSO…

Oracle中修改遇到“ORA-00054: 資源正忙, 但指定以 NOWAIT 方式獲取資源, 或者超時失效”

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 Oracle 11g中想修改表名&#xff1a; rename ASSETPORJECT to ASSETPROJECT; 結果提示&#xff1a;ORA-00054: 資源正忙, 但指定以 NOWA…

NWCD

1.java jdk和jre 求和算法 時間復雜度和空間復雜度 restful風格 微服務 maven中央倉庫 項目依賴jar包&#xff0c;換平臺運行 同步和異步 設計模式–代理模式 2.linux 僵尸進程和孤兒進程 如何消除僵尸進程 僵尸進程能被kill調嗎 磁盤性能分析iostat top free fdisk swap中a…

解決設置了background-size: cover; 但是圖片在ios下顯示不完整的問題

設置 background-size: 100% 99.9%&#xff1b; 轉載于:https://www.cnblogs.com/kugeliu/p/9469207.html

Python學習之路20-數據模型

《流暢的Python》筆記。本篇是Python進階篇的開始。本篇主要是對Python特殊方法的概述。1. 前言 數據模型其實是對Python框架的描述&#xff0c;它規范了這門語言自身構件模塊的接口&#xff0c;這些模塊包括但不限于序列、迭代器、函數、類和上下文管理器。不管在哪種框架下寫…

String s1==s2面試題

這個程序運行的結果是什么&#xff1f;class StringTest1{public static void main(String[] args) {String s1"equal";String s2 "equal";if(s1s2){System.out.println("s1s2");}else{ System.out.println("s1!s2");} }} 輸出 s1…

Vector:動態數組的使用和說明

摘自百度百科&#xff1a; 1. Vector 類在 java 中可以實現自動增長的對象數組; 創建了一個向量類的對象后&#xff0c;可以往其中隨意地插入不同的類的對象&#xff0c;既不需顧及類型也不需預先選定向量的容量&#xff0c;并可方便地進行查找。對于預先不知或不愿預先定義數組…

Spring AOP 代理模式

記錄幾篇關于AOP & 代理模式 的博客&#xff0c;寫的非常好&#xff0c;感謝作者分享&#xff01; Java中的代理模式——靜態代理以及分析靜態代理的缺點 Java中動態代理的兩種方式JDK動態代理和cglib動態代理以及區別 Spring中的AOP以及切入點表達式和各種通知 Spring…

mongodb 多表查詢

今天有一個業務涉及到mongodb的多表查詢&#xff0c;大體記錄下語句結構 db.table_a.aggregate([ {$lookup:{from:"table_b",localField:"userid",foreignField:"userid",as:"organization_doc"}}, //聯表B{ $project:{ _id:1, card…

跨平臺多線程編程

多線程介紹POSIX 1003.1-2001 定義了多線程編程的標準API。這個API就是廣為人知的pthreads。它的目的在于為跨平臺編寫多線程程序提供便利。多線程程序的編寫本文介紹了Linux 和 WIN32 平臺下的多線程程序的編寫方法Linux 系統對 pthreads 提供了良好的支持。一般地安裝完Linux…

方法重載和方法重寫

方法重載 &#xff08;1&#xff09; 方法重載是讓類以統一的方式處理不同類型數據的一種手段。多個同名函數同時存在&#xff0c;具有不同的參數個數/類型。 重載Overloading是一個類中多態性的一種表現。 &#xff08;2&#xff09; Java的方法重載&#xff0c;就是在類中可以…

shell獲取/etc/passwd中的用戶名和id

核心思想&#xff1a;cut 關鍵詞&#xff1a;head tail cut #!/bin/bash # get the information about /etc/passwd PATH/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin export PATHfile"/etc/passwd" linewc -l $file | cut -d" "…

進度條控制(Windows 公共進度欄控件的功能)

MSDN&#xff1a;https://msdn.microsoft.com/zh-cn/library/sys15k39.aspx 構造 CProgressCtrl 對象&#xff1a;  CProgressCtrl(); 創建進度欄控件&#xff1a;  virtual BOOL Create( DWORD dwStyle(風格), const RECT& rect(位置大小), CWnd* pParentWnd(父窗體),…

本地瀏覽器緩存sessionStorage(臨時存儲) localStorage(長期存儲)的使用

對瀏覽器來說&#xff0c;使用 Web Storage 存儲鍵值對比存儲 Cookie 方式更直觀&#xff0c;而且容量更大&#xff0c;它包含兩種&#xff1a;localStorage 和 sessionStorage sessionStorage&#xff08;臨時存儲&#xff09; &#xff1a;為每一個數據源維持一個存儲區域&am…