创新互联OceanBase教程:OceanBaseCOALESCE

COALESCE 函数返回参数列表中第一个非空表达式,必须指定最少两个参数。

创新互联专注于企业成都全网营销、网站重做改版、图木舒克网站定制设计、自适应品牌网站建设、HTML5建站商城开发、集团公司官网建设、外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为图木舒克等各大城市提供网站开发制作服务。

语法


COALESCE(expr1, expr2[,…, exprn])

参数

参数

说明

expr1, expr2[,…, exprn]

非空表达式,且最少 2 个。

返回类型

返回参数列表中第一个非空表达式,如果所有的参数都是 NULL,则返回 NULL

示例

假设有一张表 product_informationproduct_id 为商品 ID,list_price 为该商品原价,min_price 为商品最低价,Sale 为商品实际售价。设置商品折扣为 9 折,计算各商品的实际售价。此时可使用 COALESCE 函数,若 list_price 为空,就按最低价 min_price 计算;若 min_price 也为空,则按 5 计算。

您可以执行以下语句,建立 product_information 数据表,并插入数据:


CREATE TABLE product_information(supplier_id INT, product_id INT,list_price numeric, min_price numeric);
INSERT INTO PRODUCT_INFORMATION VALUES ('102050', '1659', '45', NULL);
INSERT INTO PRODUCT_INFORMATION VALUES ('102050', '1770', NULL, '70');
INSERT INTO PRODUCT_INFORMATION VALUES ('102050', '2370', '305', '247');
INSERT INTO PRODUCT_INFORMATION VALUES ('102050', '2380', '750', '731');
INSERT INTO PRODUCT_INFORMATION VALUES ('102050', '3255', NULL, NULL);

执行以下查询语句:


SELECT product_id, list_price,min_price,COALESCE(0.9*list_price, min_price, 5) "Sale" 
FROM product_information WHERE supplier_id = 102050 ORDER BY product_id;

查询结果如下:


+--------------+--------------+------------+--------+
|  PRODUCT_ID  |  LIST_PRICE  |  MIN_PRICE |  Sale  |
+--------------+--------------+------------+--------+
|        1659  |       45     |            |  40.5  |
+--------------+--------------+------------+--------+
|        1770  |              |     70     |    70  |
+--------------+--------------+------------+--------+
|        2370  |      305     |    247     | 274.5  |
+--------------+--------------+------------+--------+
|        2380  |      750     |    731     |   675  |
+--------------+--------------+------------+--------+
|        3255  |              |            |     5  |
+--------------+--------------+------------+--------+

网页名称:创新互联OceanBase教程:OceanBaseCOALESCE
文章分享:http://www.shufengxianlan.com/qtweb/news49/208949.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联