sql 如果字段为空就用另一个字段

您可以使用COALESCE()函数CASE WHEN表达式来处理这个逻辑:

方案一:使用COALESCE()函数(推荐)

SELECTbpi.batch_idASbatchId,bpi.batch_nameASbatchName,bpi.plate_nameASplateName,bpi.categoryASproductType,bpi.product_idASproductId,bpi.product_nameASproductName,bpi.opening_timeASopeningTime,bpi.section_idASsectionId,bpi.section_nameASsectionName,bpi.company_idAScompanyId,bpi.company_nameASsupplier,bpi.purchase_typeASpurchaseType,COALESCE(bpi.winning_bid_amount,bpi.bid_price)ASwinningBidAmountFROMbid_project_info bpi

方案二:使用CASE WHEN表达式

SELECTbpi.batch_idASbatchId,bpi.batch_nameASbatchName,bpi.plate_nameASplateName,bpi.categoryASproductType,bpi.product_idASproductId,bpi.product_nameASproductName,bpi.opening_timeASopeningTime,bpi.section_idASsectionId,bpi.section_nameASsectionName,bpi.company_idAScompanyId,bpi.company_nameASsupplier,bpi.purchase_typeASpurchaseType,CASEWHENbpi.winning_bid_amountISNULLTHENbpi.bid_priceELSEbpi.winning_bid_amountENDASwinningBidAmountFROMbid_project_info bpi

方案三:使用IFNULL()函数(MySQL、SQLite等)

SELECTbpi.batch_idASbatchId,bpi.batch_nameASbatchName,bpi.plate_nameASplateName,bpi.categoryASproductType,bpi.product_idASproductId,bpi.product_nameASproductName,bpi.opening_timeASopeningTime,bpi.section_idASsectionId,bpi.section_nameASsectionName,bpi.company_idAScompanyId,bpi.company_nameASsupplier,bpi.purchase_typeASpurchaseType,IFNULL(bpi.winning_bid_amount,bpi.bid_price)ASwinningBidAmountFROMbid_project_info bpi

方案四:使用ISNULL()函数(SQL Server)

SELECTbpi.batch_idASbatchId,bpi.batch_nameASbatchName,bpi.plate_nameASplateName,bpi.categoryASproductType,bpi.product_idASproductId,bpi.product_nameASproductName,bpi.opening_timeASopeningTime,bpi.section_idASsectionId,bpi.section_nameASsectionName,bpi.company_idAScompanyId,bpi.company_nameASsupplier,bpi.purchase_typeASpurchaseType,ISNULL(bpi.winning_bid_amount,bpi.bid_price)ASwinningBidAmountFROMbid_project_info bpi

📌 各方案对比

方案函数适用数据库特点
方案一COALESCE()所有主流数据库(标准SQL)最通用,可处理多个参数,返回第一个非NULL值
方案二CASE WHEN所有数据库最灵活,可处理复杂条件
方案三IFNULL()MySQL、SQLite、MariaDB简洁,但只适用于特定数据库
方案四ISNULL()SQL ServerSQL Server专用

💡 推荐与说明

推荐使用方案一的COALESCE()函数,原因如下:

  1. 标准化COALESCE()是 SQL 标准函数,在所有主流数据库(MySQL、PostgreSQL、Oracle、SQL Server、SQLite等)中都可用
  2. 可扩展性:可以处理多个字段的优先级,例如:
    COALESCE(bpi.winning_bid_amount,bpi.bid_price,bpi.estimate_price,0)ASwinningBidAmount
    (依次尝试 winning_bid_amount、bid_price、estimate_price,都为空则返回 0)
  3. 简洁性:代码比CASE WHEN更简洁

🔍 完整查询示例

SELECTbpi.batch_idASbatchId,bpi.batch_nameASbatchName,bpi.plate_nameASplateName,bpi.categoryASproductType,bpi.product_idASproductId,bpi.product_nameASproductName,bpi.opening_timeASopeningTime,bpi.section_idASsectionId,bpi.section_nameASsectionName,bpi.company_idAScompanyId,bpi.company_nameASsupplier,bpi.purchase_typeASpurchaseType,-- 如果winning_bid_amount为空,则使用bid_priceCOALESCE(bpi.winning_bid_amount,bpi.bid_price)ASwinningBidAmountFROMbid_project_info bpiWHERE...-- 可以添加其他查询条件ORDERBY...-- 可以添加排序

⚠️ 注意事项

  1. 确保bid_price字段存在于bid_project_info表中
  2. 如果bid_price也可能为 NULL,可以使用嵌套的COALESCE()或设置默认值:
    COALESCE(bpi.winning_bid_amount,bpi.bid_price,0)ASwinningBidAmount
  3. 数据类型要兼容:winning_bid_amountbid_price应该是相同或兼容的数据类型(如都是 DECIMAL、FLOAT 等)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1160638.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android 基础入门教程2.5.2 GridView(网格视图)的基本使用

2.5.2 GridView(网格视图)的基本使用 分类 Android 基础入门教程 本节引言: 本节给大家介绍的是第二个Adapter类的控件——GridView(网格视图),见名知义,ListView是列表, GridView就是显示网格!他和ListView一样是Ab…

Android 基础入门教程2.5.3 Spinner(列表选项框)的基本使用

2.5.3 Spinner(列表选项框)的基本使用 分类 Android 基础入门教程 本节引言: 本来本节是想给大家介绍一个Gallery(画廊)的一个控件的,后来想想还是算了,因为 在Android 4.1后就已经被弃用了,尽管我们可以通过兼容不来使用Galler…

AI赋能央企数智化转型研究报告:AI赋能央企转型应用现状、AI赋能央企转型路径与挑战、AI赋能央企转型服务商体系、未来展望

本报告全面描绘了AI驱动央企数智化转型的宏大图景。其核心逻辑是:在国家战略强力驱动下,央企正以AI为核心引擎,通过构建自主可控的技术底座、推动AI向全业务核心场景深度渗透、并牵头构建协同创新的产业生态,最终实现自身高质量发…

大模型推理框架对比:SGLang 与 vLLM 的核心差异解析

在大模型推理引擎领域,vLLM 凭借高效的 KV 缓存管理与连续批处理技术,成为高并发场景的主流选择;而同源(LMSYS Org)的 SGLang 则以“结构化生成”为核心突破,重新定义了复杂 LLM 应用的开发范式。两者虽师出…

​ Android 基础入门教程​2.5.4 AutoCompleteTextView(自动完成文本框)的基本使用

2.5.4 AutoCompleteTextView(自动完成文本框)的基本使用 分类 Android 基础入门教程 本节引言: 本节继续来学习Adapter类的控件,这次带来的是AutoCompleteTextView(自动完成文本框), 相信细心的你发现了,和Adapter搭边的控件&am…

Agent搭建-超详细教程,存一下吧

AI Agent在于其能自动执行复杂任务,大幅提升自动化和智能决策的效率,让任务自动化,主要包括感知、记忆、规划与决策、行动/使用工具。 AI Agent的工作原理分为几个步骤。 ✔首先是感知,AI Agent通过传感器感知物理或虚拟环境中的变…

事务中的隔离性是如何保证的呢?(你解释一下MVCC)

事务的隔离性通过锁和多版本并发控制(MVCC)来保证。MVCC通过维护数据的多个版本来避免读写冲突。底层实现包括隐藏字段、undo log和read view。隐藏字段包括trx_id和roll_pointer。undo log记录了不同版本的数据,通过roll_pointer形成版本链。…

数据治理到底应该怎么治理?治理什么?在哪治理?治理路径是什么?治理流程又是什么?附案例及解决方案

数据治理是对组织内数据资产的系统性管理,核心是建立权责清晰的组织、统一的规范(标准、质量、安全)以及可持续的流程。其治理对象覆盖数据的全生命周期,治理范围贯穿所有业务与系统。治理路径应以价值为导向,从关键业…

如何在liunx环境安装PageAdmin Cms系统

web系统一般建议安装在srv/wwwoot目录下,下面步骤演示如何安装pageadmin版本。 1、进入srv目录,创建wwwroot/demo目录,生产环境demo替换为网站标识或域名标识,方便后期识别。2、上传web文件zip压缩包到 /srv/wwwroot/demo目录下解…

2026常见的企业网站建设系统推荐

如今,网站已成为企业开展网络营销、展示品牌形象的重要载体,几乎各个行业的企业都会选择搭建专属官网。对于非专业背景或缺乏建站经验的企业而言,选择成熟的第三方 PHP 网站系统或 CMS(内容管理系统)框架,是…

既然强转会报错,java为啥不封装处理好,避免强转报错?

✅ 用【大白话 人话】彻底讲懂,不讲原理、只讲结论、保证听懂,0 基础也能明白!你不懂太正常了,这个问题本身就是 Java 的反直觉坑,咱们抛开所有专业术语,只说人话、只讲你关心的「为什么」和「怎么办」&am…

帧同步游戏设置一个“固定输入延迟”它背后的逻辑

大部分帧同步游戏会设置一个“固定输入延迟”,比如: 所有操作都延迟“3~5 帧”生效。 表面意思: 你按下技能/移动,这个操作不是立刻在逻辑上生效,而是“排队”等几帧。 很多人一看就懵: “为啥要故意搞个延迟?不就更卡了吗?我明明想要手感更快的啊!” 这一篇就专门围…

mkcert 本地 HTTPS 证书全平台教程

摘要: 本文提供跨平台本地HTTPS证书生成方案,使用mkcert工具在Windows/macOS/Linux统一创建可信证书。核心步骤包括:1)各平台安装mkcert;2)生成证书文件(含私钥);3&…

合集(WORD+PPT):AI大模型赋能数字政府智慧政务、智慧党建、社会治理、基层治理、市域治理等

AI大模型通过智能政务助手、政策精准匹配、智能审批等提升服务效率;赋能党员教育、党建知识问答、组织生活管理;并助力社情民意分析、矛盾调解和城市智能治理,构建高效、精准、协同的数字政府新体系。500余份合集(WORDPPT&#xf…

Day01-07.搭建项目环境-测试部署的微服务14:20

就是之前做过的那个单体项目,小程序,的微服务版本,加了一些主流技术栈,挺好的,可以上手实操看看。把学过的技术栈实操看看。每次工作有时间了,就学点新技术没时间也要创造时间,目前就是创造时间…

VR禁毒知识信息平台:科技赋能全民禁毒教育新载体

一、产品内容:构建“全链条内容多技术支撑广受众适配”禁毒教育体系VR禁毒知识信息平台核心定位为“全景化、互动化、全民化”的禁毒知识传播与教育平台,旨在打破时空限制,让公众沉浸式学习禁毒知识、掌握防毒拒毒技巧,最终提升全…

A17-300余份AI大模型赋能教育、数字校园、智慧高校、智慧教育、教育大脑、高校大脑、智慧职教、智慧幼教(PPT+WORD,见文末)

AI大模型正在将“数字校园”的静态基础设施,转化为一个能感知、会思考、可进化、有温度的“智慧教育生命体”。其成功的关键在于始终以人的成长与发展为中心,实现技术赋能与人文关怀的完美平衡。A17-300余份AI大模型赋能教育、数字校园、智慧高校、智慧教…

【原创】使用langchain与MCP 与 Chrome DevTools 打造可调用浏览器工具的 Chat Agent

本文介绍如何搭建基于Chrome开发者工具多客户端协议(MCP)的智能对话代理。通过整合chrome-devtools-mcp和LangChain框架,实现了自动注册MCP工具、支持Ollama/OpenAI双模型后端、异步非阻塞运行的Chat Agent。文章详细说明了环境配置方法,包括Chrome调试模…

22.C++进阶:⼆叉搜索树|手撕二叉搜索树

⼆叉搜索树的概念 ⼆叉搜索树⼜称⼆叉排序树,它或者是⼀棵空树,或者是具有以下性质的⼆叉树: 若它的左⼦树不为空,则左⼦树上所有结点的值都⼩于等于根结点的值若它的右⼦树不为空,则右⼦树上所有结点的值都⼤于等于根结点的值它的…

搞定JAX高效并行训练

💓 博客主页:借口的CSDN主页 ⏩ 文章专栏:《热点资讯》 搞定JAX高效并行训练:从理论到实战的深度探索目录搞定JAX高效并行训练:从理论到实战的深度探索 引言:为何JAX并行训练是AI工程的分水岭 一、JAX并行训…