SQL的CASE WHEN函数、CAST函数、CONVERT() 函数、COALESCE()函数、DATEDIFF()函数

这篇具有很好参考价值的文章主要介绍了SQL的CASE WHEN函数、CAST函数、CONVERT() 函数、COALESCE()函数、DATEDIFF()函数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、CASE WHEN简单使用

SELECT
CASE
WHEN age >= 18 AND age <= 25 THEN '18-25'

WHEN age > 25 AND age <= 35 THEN '25-35'

WHEN age > 35 AND age <= 45 THEN '36-45'

ELSE '45+'

END AS age_group

FROM people

GROUP BY age_group;

二、CASE WHEN语句与聚合函数一起使用

SELECT 
COUNTRY, 
SUM(CASE SEX WHEN '1' THEN POPULATION ELSE 0 END) AS '男',
SUM(CASE SEX WHEN '2' THEN PUPULATION ELSE 0 END) AS '女'
FORM TABLE_A GROUP BY COUNTRY

三、CAST函数

用于将某种数据类型的表达式显式转换为另一种数据类型。CAST()函数的参数是一个表达式,它包括用AS关键字分隔的源值和目标数据类型。

语法:CAST (expression AS data_type)

expression:任何有效的SQServer表达式。
AS:用于分隔两个参数,在AS之前的是要处理的数据,在AS之后是要转换的数据类型。
data_type:目标系统所提供的数据类型,包括bigint和sql_variant,不能使用用户定义的数据类型。

可以转换的类型是有限制的。这个类型可以是以下值其中的一个:

二进制 BINARY
字符型 可带参数 : CHAR()
DATE DATE
时间 TIME
日期时间型 DATETIME
浮点数 DECIMAL
整数 SIGNED
无符号整数 UNSIGNED

:

实例:
1.SELECT CAST('1.0' AS decimal)  结果:1

2.SELECT CAST('9.5' AS decimal(10,2))  结果:9.50(精度与小数位数分别为102

3.SELECT  CAST(NOW() AS   DATE) 结果:2017-11-27

四、CONVERT() 函数

定义和用法:

ONVERT() 函数是把日期转换为新数据类型的通用函数。
CONVERT() 函数可以用不同的格式显示日期/时间数据。

语法

CONVERT(data_type(length),data_to_be_converted,style)

data_type(length) 规定目标数据类型(带有可选的长度)。data_to_be_converted 含有需要转换的值。style 规定日期/时间的输出格式

Style ID Style 格式
100 或者 0 mon dd yyyy hh:miAM (或者 PM)
101 mm/dd/yy
102 yy.mm.dd
103 dd/mm/yy
104 dd.mm.yy
105 dd-mm-yy
106 dd mon yy
107 Mon dd, yy
108 hh:mm:ss
109 或者 9 mon dd yyyy hh:mi:ss:mmmAM(或者 PM)
110 mm-dd-yy
111 yy/mm/dd
112 yymmdd
113 或者 13 dd mon yyyy hh:mm:ss:mmm(24h)
114 hh:mi:ss:mmm(24h)
120 或者 20 yyyy-mm-dd hh:mi:ss(24h)
121 或者 21 yyyy-mm-dd hh:mi:ss.mmm(24h)
126 yyyy-mm-ddThh:mm:ss.mmm(没有空格)
130 dd mon yyyy hh:mi:ss:mmmAM
131 dd/mm/yy hh:mi:ss:mmmAM

我们将使用 GETDATE() 函数来获得当前的日期/时间:

CONVERT(VARCHAR(19),GETDATE())
CONVERT(VARCHAR(10),GETDATE(),110) 
CONVERT(VARCHAR(11),GETDATE(),106)
CONVERT(VARCHAR(24),GETDATE(),113)

结果:

Dec 29 2008 11:45 PM
12-29-2008
29 Dec 08
29 Dec 2008 16:25:46.635

五、COALESCE()函数

COALESCE函数是用来处理NULL值的一个函数

简介:

COALESCE函数并非某个数据库的专有函数,它是标准的SQL函数,被许多数据库系统支持。一些广泛使用的数据库系统,如MySQL、PostgreSQL、SQLite、SQL Server、Oracle等,都实现了COALESCE函数。尽管各数据库实现和性能可能略有不同,但其核心功能和语法在各个数据库中基本保持一致。

语法:
COALESCE函数是SQL中的一个非常实用的函数,它可以用于返回一系列参数中的第一个非空值。如果所有参数都为NULL,COALESCE函数将返回NULL。

COALESCE(value1, value2, ..., valueN)
SELECT
  pid,
  SUM(COALESCE(units_sold, 0)) AS total_units_sold
FROM
  A
GROUP BY
  pid;
进阶:

SELECT
  *,
  COALESCE(
    (CASE
      WHEN e1.pid IS NOT NULL THEN
        e2.first_name || ' ' || e2.last_name
    END),
    'N/A'
  ) AS sn
FROM
  A e1
LEFT JOIN B e2 ON e1.pid = e2.eid;

注意:

  1. 数据类型一致性:尽管COALESCE函数允许检查多个值,但请确保这些值具有相同或兼容的数据类型。如果数据类型不兼容,可能会导致错误或难以预测的结果。
  2. 避免过多嵌套:虽然可以在COALESCE函数内嵌套其他函数,但过多的嵌套可能会导致代码难以阅读和维护。如果需要实现复杂逻辑,请考虑使用CASE语句或将逻辑拆分到多个查询中。
  3. NULL值处理:了解如何在特定场景下处理NULL值很重要。在某些情况下,使用COALESCE函数可能不是最佳选择。例如,如果你需要筛选出非NULL值的行,可以使用IS NOT NULL条件而不是COALESCE。
  4. 数据库特定实现:虽然COALESCE函数在许多数据库系统中都有实现,但它们之间可能存在一些差异。在使用COALESCE函数时,请参考你正在使用的数据库系统的文档,了解其特定实现和最佳实践。
  5. 适当的默认值:在使用COALESCE函数指定默认值时,请确保选择的默认值在上下文中具有意义。例如,如果您正在处理数字数据,使用0作为默认值可能比较合适;而对于文本数据,空字符串(‘’)可能是一个更好的选择。
  6. 性能影响:COALESCE函数在处理大量数据时可能会影响性能。尽量优化查询,避免不必要的计算,以提高性能。

六、DATEDIFF ( datepart , startdate , enddate )释义:计算时间差;

datepare值:year | quarter | month | week | day | hour | minute | second | millisecond
startdate:开始日期
enddate :结束日期
GetDate():获取当前的系统日期

下面例子中表名为tablename,条件字段名为inputdate文章来源地址https://www.toymoban.com/news/detail-727091.html

查询今天

SELECT * FROM tablename where DATEDIFF(day,inputdate,GETDATE())=0

查询昨天

SELECT * FROM tablename where DATEDIFF(day,inputdate,GETDATE())=1

查询本周

SELECT * FROM tablename where DATEDIFF(week,inputdate,GETDATE())=0

查询上周

SELECT * FROM tablename where DATEDIFF(week,inputdate,GETDATE())=1

查询本月

SELECT * FROM tablename where DATEDIFF(month,inputdate,GETDATE())=0

查询上月

SELECT * FROM tablename where DATEDIFF(month,inputdate,GETDATE())=1

到了这里,关于SQL的CASE WHEN函数、CAST函数、CONVERT() 函数、COALESCE()函数、DATEDIFF()函数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SQL SERVER case when的使用方法

    一、case when的使用方法 Case具有两种格式。简单Case函数和Case搜索函数。 第一种 格式 : 简单Case函数 : 格式说明 case 列名 when 条件值1 then 选项1 when 条件值2 then 选项2… else 默认值 end eg: select case job_level when ‘1’ then ‘1111’ when ‘2’ then ‘1111’ when ‘3’ then ‘1111’ else ‘e

    2024年02月13日
    浏览(72)
  • SQL中的CASE WHEN语句:从基础到高级应用指南

    我们使用一个名为\\\"Products\\\"的表,包含以下列:ProductID、ProductName、CategoryID、UnitPrice、StockQuantity。 示例展示 productID productName categoryID unitPrice stockQuantity 1 Laptop 1 800 50 2 Smartphone 1 500 100 3 T-shirt 2 20 200 4 Jeans 2 40 150 5 Headphones 1 100 75 1. CASE WHEN-基本使用 查询结果: ProductName UnitPric

    2024年02月09日
    浏览(73)
  • hive SQL: case when + group by 的用法

    假设有一个数据表,包含了不同人员的信息,其中包括姓名、性别、年龄等字段。现在需要统计不同年龄区间的人数,并按照年龄区间进行分组。可以使用如下 SQL 语句实现: ``` SELECT    CASE      WHEN age BETWEEN 0 AND 10 THEN \\\'0-10\\\'      WHEN age BETWEEN 11 AND 20 THEN \\\'11-20\\\'      WHEN a

    2024年02月08日
    浏览(79)
  • SQL的DATEDIFF( )函数

    DATEDIFF() 是 SQL 中的日期函数,用于计算两个日期之间的差值。 其语法如下: 其中, datepart 是表示差值单位的或缩写; startdate 和 enddate 表示要计算差值的两个日期。 datepart 参数可以是以下值之一: year, yy, yyyy: 年 quarter, qq, q: 季度 month, mm, m: 月 dayofyear, dy, y: 年中的天

    2024年02月14日
    浏览(47)
  • sql中COALESCE函数详解

    在SQL中, COALESCE 函数是一个非常有用的函数,用于从其参数列表中返回第一个非 NULL 值。如果所有给定的参数都是 NULL ,那么 COALESCE 函数将返回 NULL 。这个函数可以接受多个参数,使其在处理可能出现的 NULL 值时非常灵活和强大。 语法 expression1, expression2, ..., expressionN :是

    2024年04月27日
    浏览(31)
  • sql coalesce函数 (全网最详细解读 案例)

    目录  一、函数COALESCE 二、解读  三、使用 1.0版本  2.0版本——行转列中会用到coalesce() 案例sql COALESCE(expression_1, expression_2, ...,expression_n) coalesce( f1, f2, f3, ... fn) coalesce用于:f1有值,返回f1,若为null,则看f2,f2有值,则返回f2,若为null,继续往后。以此类推。 简单说就是:

    2024年02月04日
    浏览(51)
  • SQL Server日期时间加减函数–DATEDIFF、DateAdd

    1.DATEDIFF语法 2. datepart: 时间类型 datepart 缩写 年 yy, yyyy 季度 qq, q 月 mm, m 年中的日 dy, y 日 dd, d 周 wk, ww 星期 dw, w 小时 hh 分钟 mi, n 秒 ss, s 毫秒 ms 微妙 mcs 纳秒 ns 3.DATEDIFF示列 1.DATEADD语法 2. datepart: 时间类型 datepart 缩写 年 yy, yyyy 季度 qq, q 月 mm, m 年中的日 dy, y 日 dd, d 周 wk,

    2024年02月13日
    浏览(53)
  • SQL中CONVERT()函数用法详解

    SQL中CONVERT函数格式: CONVERT(data_type,expression[,style]) 参数说明: expression 是任何有效的 Microsoft® SQL Server™ 表达式。。 data_type 目标系统所提供的数据类型,包括 bigint 和 sql_variant。不能使用用户定义的数据类型。 length nchar、nvarchar、char、varchar、binary 或 varbinary 数据类型的可选参

    2024年02月05日
    浏览(56)
  • SQL Server函数CONVERT–日期时间格式转换

    语法: 1.值描述 data_type(length) 规定目标数据类型(带有可选的长度)。 expression 规定需要转换的值。 style 规定日期/时间的输出格式。 2.cast()和convert()函数比较 cast一般更容易使用,convert的优点是可以格式化日期和数值; convert一般用于日期和时间类型以及小数之间转换,而

    2024年02月03日
    浏览(62)
  • SQL中CONVERT转化日期函数的使用方法

    SQL中CONVERT函数最常用的是使用convert转化长日期为短日期,如果只要取yyyy-mm-dd格式时间, 就可以用 convert(nvarchar(10),field,120) 120 是格式代码, nvarchar(10) 是指取出前10位字符. 例如 ================================ select CONVERT(varchar, getdate(), 120 ) 2023-06-05 16:22:43 select replace(replace(replace(CONVE

    2024年02月10日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包