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

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

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

sql 复制代码
SELECT
    bpi.batch_id AS batchId,
    bpi.batch_name AS batchName,
    bpi.plate_name AS plateName,
    bpi.category AS productType,
    bpi.product_id AS productId,
    bpi.product_name AS productName,
    bpi.opening_time AS openingTime,
    bpi.section_id AS sectionId,
    bpi.section_name AS sectionName,
    bpi.company_id AS companyId,
    bpi.company_name AS supplier,
    bpi.purchase_type AS purchaseType,
    COALESCE(bpi.winning_bid_amount, bpi.bid_price) AS winningBidAmount
FROM bid_project_info bpi

方案二:使用 CASE WHEN 表达式

sql 复制代码
SELECT
    bpi.batch_id AS batchId,
    bpi.batch_name AS batchName,
    bpi.plate_name AS plateName,
    bpi.category AS productType,
    bpi.product_id AS productId,
    bpi.product_name AS productName,
    bpi.opening_time AS openingTime,
    bpi.section_id AS sectionId,
    bpi.section_name AS sectionName,
    bpi.company_id AS companyId,
    bpi.company_name AS supplier,
    bpi.purchase_type AS purchaseType,
    CASE 
        WHEN bpi.winning_bid_amount IS NULL THEN bpi.bid_price
        ELSE bpi.winning_bid_amount
    END AS winningBidAmount
FROM bid_project_info bpi

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

sql 复制代码
SELECT
    bpi.batch_id AS batchId,
    bpi.batch_name AS batchName,
    bpi.plate_name AS plateName,
    bpi.category AS productType,
    bpi.product_id AS productId,
    bpi.product_name AS productName,
    bpi.opening_time AS openingTime,
    bpi.section_id AS sectionId,
    bpi.section_name AS sectionName,
    bpi.company_id AS companyId,
    bpi.company_name AS supplier,
    bpi.purchase_type AS purchaseType,
    IFNULL(bpi.winning_bid_amount, bpi.bid_price) AS winningBidAmount
FROM bid_project_info bpi

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

sql 复制代码
SELECT
    bpi.batch_id AS batchId,
    bpi.batch_name AS batchName,
    bpi.plate_name AS plateName,
    bpi.category AS productType,
    bpi.product_id AS productId,
    bpi.product_name AS productName,
    bpi.opening_time AS openingTime,
    bpi.section_id AS sectionId,
    bpi.section_name AS sectionName,
    bpi.company_id AS companyId,
    bpi.company_name AS supplier,
    bpi.purchase_type AS purchaseType,
    ISNULL(bpi.winning_bid_amount, bpi.bid_price) AS winningBidAmount
FROM bid_project_info bpi

📌 各方案对比

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

💡 推荐与说明

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

  1. 标准化COALESCE() 是 SQL 标准函数,在所有主流数据库(MySQL、PostgreSQL、Oracle、SQL Server、SQLite等)中都可用

  2. 可扩展性 :可以处理多个字段的优先级,例如:

    sql 复制代码
    COALESCE(bpi.winning_bid_amount, bpi.bid_price, bpi.estimate_price, 0) AS winningBidAmount

    (依次尝试 winning_bid_amount、bid_price、estimate_price,都为空则返回 0)

  3. 简洁性 :代码比 CASE WHEN 更简洁

🔍 完整查询示例

sql 复制代码
SELECT
    bpi.batch_id AS batchId,
    bpi.batch_name AS batchName,
    bpi.plate_name AS plateName,
    bpi.category AS productType,
    bpi.product_id AS productId,
    bpi.product_name AS productName,
    bpi.opening_time AS openingTime,
    bpi.section_id AS sectionId,
    bpi.section_name AS sectionName,
    bpi.company_id AS companyId,
    bpi.company_name AS supplier,
    bpi.purchase_type AS purchaseType,
    -- 如果winning_bid_amount为空,则使用bid_price
    COALESCE(bpi.winning_bid_amount, bpi.bid_price) AS winningBidAmount
FROM bid_project_info bpi
WHERE ...  -- 可以添加其他查询条件
ORDER BY ...  -- 可以添加排序

⚠️ 注意事项

  1. 确保 bid_price 字段存在于 bid_project_info 表中

  2. 如果 bid_price 也可能为 NULL,可以使用嵌套的 COALESCE() 或设置默认值:

    sql 复制代码
    COALESCE(bpi.winning_bid_amount, bpi.bid_price, 0) AS winningBidAmount
  3. 数据类型要兼容:winning_bid_amountbid_price 应该是相同或兼容的数据类型(如都是 DECIMAL、FLOAT 等)

相关推荐
m0_4665252926 分钟前
绿盟科技风云卫AI安全能力平台成果重磅发布
大数据·数据库·人工智能·安全
爱学习的阿磊1 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
枷锁—sha1 小时前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞1 小时前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle
chian-ocean1 小时前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
m0_550024631 小时前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦1 小时前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_99992 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同7652 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码3 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql