odoo-061 PostgreSQL 中處理 NULL 值的 SQL 條件寫法

文章目錄

  • 1. 檢查是否為 NULL
  • 2. NULL 值與比較運算符
  • 3. 在聚合函數中處理 NULL
  • 4. 在 WHERE 子句中的復雜條件
  • 注意事項

在 PostgreSQL 中處理 NULL 值需要特別注意,因為 NULL 表示"未知"或"不存在"的值,與普通值的行為不同。以下是幾種處理 NULL 值的 SQL 條件寫法:

1. 檢查是否為 NULL

-- 使用 IS NULL 檢查 NULL 值
SELECT * FROM table_name WHERE column_name IS NULL;-- 使用 IS NOT NULL 檢查非 NULL 值
SELECT * FROM table_name WHERE column_name IS NOT NULL;

2. NULL 值與比較運算符

-- 以下寫法不會返回任何行,因為 NULL 不能與任何值比較
SELECT * FROM table_name WHERE column_name = NULL;  -- 錯誤寫法
SELECT * FROM table_name WHERE column_name != NULL; -- 錯誤寫法-- 正確寫法是使用 IS NULL 或 IS NOT NULL

3. 在聚合函數中處理 NULL

-- COUNT 會忽略 NULL 值
SELECT COUNT(column_name) FROM table_name;  -- 只計算非 NULL 值
SELECT COUNT(*) FROM table_name;            -- 計算所有行,包括 NULL 值-- 其他聚合函數如 SUM, AVG 也會忽略 NULL 值

4. 在 WHERE 子句中的復雜條件

-- 查找值為 NULL 或滿足特定條件的行
SELECT * FROM table_name 
WHERE column_name IS NULL OR column_name = 'some_value';-- 查找值不為 NULL 且滿足特定條件的行
SELECT * FROM table_name 
WHERE column_name IS NOT NULL AND column_name LIKE 'A%';

注意事項

  • NULL 不等于空字符串 ‘’,也不等于 0
  • 任何與 NULL 的算術運算結果都是 NULL
  • 在 UNIQUE 約束中,NULL 值被視為彼此不同(允許多個 NULL 值)
  • 在 ORDER BY 中,NULL 值默認排在最后(可使用 NULLS FIRST/NULLS LAST 調整)

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

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

相關文章

Flink CDC 介紹

一、什么是 CDCCDC 是 Change Data Capture(變更數據獲取)的簡稱。核心思想是,監測并捕獲數據庫的變動(包括數據或數據表的插入、更新以及刪除等),將這些變更按發生的順序完整記錄下來,寫入到消息中間件中以供其他服務…

暑期第三周(7.28-8.3)

其實 web [SWPUCTF 2021 新生賽]easy_sql 開啟環境后看到一個提示“球球你輸入點東西吧!”沒有其他信息,就看看源碼 直接試試get傳參 有所顯示 看看是字符型還是數字型 可以判定是字符型 接下來判斷閉合類型 根據顯示,可以得知是單引…

【物聯網】基于樹莓派的物聯網開發【21】——MQTT獲取樹莓派傳感器數據廣播實戰

場景介紹 今天程序貓帶領大家如何獲取樹莓派傳感器溫濕度數據,并用MQTT進行廣播。 實現過程 啟動MQTT服務 1、終端啟動Mosquitto服務 sudo systemctl start mosquitto 2、設置服務開機自動啟動 sudo systemctl enable mosquitto硬件連接 樹莓派4b連接GPIO引腳與DHT1…

Mysql自定義順序查詢

1、使用函數MySQL 的 ORDER BY FIELD() 函數可以按照指定的自定義順序對查詢結果進行排序,而不是默認的升序(ASC)或降序(DESC)。2、適用場景后端/運營人員經常需要臨時把某幾條記錄‘拽’到最前(或最后&…

回歸預測 | MATLAB實現RBF徑向基神經網絡多輸入單輸出回歸預測+SHAP可解釋分析

目錄 基于RBF徑向基神經網絡多輸入單輸出回歸預測及SHAP可解釋分析的研究 摘要 1. 引言 1.1 研究背景 1.2 研究意義 1.3 研究目標與內容 2. 文獻綜述 2.1 RBF徑向基神經網絡研究現狀 2.2 SHAP可解釋分析研究進展 3. RBF徑向基神經網絡原理 4. SHAP可解釋分析理論基礎 4.1 Shapl…

--- Eureka 服務注冊發現 ---

Euraka 是netfix開發的基于REST服務基于AP框架的注冊中心,主要是用于服務的注冊,管理,負載均衡,服務故障轉移 Eureka主要分倆部分Eureka Server:服務中心Server端,提供服務注冊 發現 健康檢查等服務Eureka …

vue3 el-select 加載內容后 觸發事件

在 Vue 3 中使用 Element UI 的 el-select 組件實現加載內容后觸發事件,主要有以下兩種常見需求及實現方式:加載數據后觸發事件若需在數據加載完成后觸發特定事件(如頁面渲染完成),可通過自定義指令監聽滾動容器狀態&a…

c# winform 調用 海康威視工業相機(又全又細又簡潔)

1.準備一個海康相機 從垃圾桶里翻出來一個USB口相機。 2.下載MVS 和SDK 海康機器人-機器視覺-下載中心 mvs: sdk: 用MVS 調試一下,能連接就行。 海康威視相機,MVS連接成功,但無圖像怎么辦?-CSDN博客 3.打…

前端頁面直接生成PDF下載文件

前言 因為要實現業務需求如下圖,業務邏輯,該憑證為前端代碼實現,為了簡單方便實現下載為pdf的需求。 一、怎么在前端直接生成PDF? 需求描述:瀏覽器打開的這個頁面,點擊下載,把當前彈框頁面的…

性能優化——GPU的影響

關閉MSAA 之前在查一個渲染問題,一開始是定位到了CPU在waitforFrame所以知道是GPU的問題但如何定義GPU的問題在哪里,就很麻煩。我一開始以為是drawcall的問題,因為我發現drawcall有350個但降低到30個后,依然情況沒有好轉。畢竟dra…

軟件需求關閉前的質量評估標準是什么

在 需求關閉前,進行 質量評估 是確保需求被完整實現、測試充分且滿足業務目標的關鍵步驟。以下是需求關閉前的質量評估標準,涵蓋了功能、非功能、測試覆蓋率和用戶滿意度等方面:一、功能實現的質量評估標準需求完整性:所有功能需求…

vscode中創建python虛擬環境的方法

文章目錄框架不同python解釋器vscode運行python需要的插件vscode可以改變執行python腳本的默認終端虛擬環境解釋創建虛擬環境的方法python的settings.json的一些好用配置框架 python解釋器->虛擬環境->vscode 不同python解釋器 在一臺電腦中我們可以安裝多個版本的pyt…

基于 ShardingSphere 的 Spring Boot 數據加密與模糊查詢實現

基于 ShardingSphere 的 Spring Boot 數據加密與模糊查詢實現 在數據安全與查詢便捷性并重的今天,敏感數據加密存儲后如何支持靈活查詢成為關鍵挑戰。本文將聚焦ShardingSphere 在實現數據加密的同時支持模糊查詢的核心能力,詳細介紹基于 Spring Boot 和 ShardingSphere 的完…

計算虛擬化技術

🧠 一、什么是計算虛擬化?(基礎認識) ? 基本概念: 計算虛擬化(Compute Virtualization) 是指:在一臺物理服務器上模擬多個“虛擬計算資源”,每個虛擬機看起來像是一臺獨…

Python編程基礎與實踐:Python基礎數據結構:列表、字典和集合

Python數據結構:掌握列表、字典和集合 學習目標 通過本課程的學習,學員將掌握Python中基本的數據結構:列表、字典和集合。學員將了解它們的特性、使用場景以及如何高效地使用它們來解決實際問題。 相關知識點 列表、字典和集合使用 學習…

三維偏序 -- cdq 套 cdq

似乎題解區并沒有 cdq 套 cdq 的作法,剛好今天講了,就來寫一發。 題意與記號 題目講的很清楚了。此方法并沒有樹狀數組好想也沒有其高效,但能很方便擴展。下文記原序列為 ddd,將每個點拆分成點與詢問,內部增加一個名為…

Effective C++ 條款27: 盡量用const、enum、inline替換 #define

Effective C 條款27:盡量用const、enum、inline替換#define核心思想:使用編譯器(const, enum, inline)替代預處理器(#define),讓編譯器進行語義檢查,避免宏替換引發的錯誤和調試困難…

芯谷科技--高效噪聲降低解決方案壓縮擴展器D5015

在無繩電話系統中,噪聲降低是提升通話質量的關鍵。 D5015 壓縮擴展器,通過集成壓縮器和擴展器,有效降低了傳輸噪聲,同時保持了信號的完整性。D5015 采用 SOP20 和 DIP20 封裝形式,具有低電壓工作、低功耗、高集成度等特…

LabVIEW車床靜剛度自動測

?基于LabVIEW 平臺開發車床靜剛度自動測試系統,針對傳統生產法測量中人工誤差大、計算復雜、效率低等問題,結合誤差復映規律與剛度方程,通過高精度硬件與軟件協同,實現試件加工前后尺寸的在線采集、自動計算與報告生成&#xff0…

汽車流通行業4S門店生存性指標:零服吸收率

我們在做汽車4S集團的商業智能BI數據分析項目中,對于4S店的管理,大家經常會提到一個分析指標,叫“零服吸收率”,這個大概是什么意思呢?簡單來說就是4S門店一臺車都沒有賣出的情況下,光靠售后服務部分的收益…