sql server 2008 年累计数_乘风破浪的 SQL

8997998c093a9935469f0a66a55e2703.png

作者 | 不剪发的Tony老师,已获授权

责编 | 屠敏

头图 | CSDN 下载自东方 IC

出品 | CSDN 博客

大家好,我是只谈技术不剪发的 Tony 老师。最近有一个非常火的综艺节目叫做《乘风破浪的姐姐》,邀请了 30 位年龄在 30 岁以上的女艺人,通过封闭式训练和考核,最终由全民投票选出 5 位成员组成全新女团。

看了这个节目之后,最有感触的不是姐姐们的多才多艺,而是她们面对人生的态度和敢于挑战自我的勇气和自信。只是对于我来说,她们当中很多人应该不是姐姐而是妹妹(一不小心暴露了年龄?)。

那么,这和 SQL 语言有什么关系呢?SQL 由 IBM 于上世纪 70 年代创建,如今已经成为了使用最广泛的数据库查询语言。不过,相信很多人对于 SQL 的理解就是关系数据库,就是增删改查;实际上,SQL 在经历了四十而不惑之后就像“姐姐们”一样成熟而有魅力,同时它又敢于在不断变化的产业需求和各种非关系模型的冲击之下实现自我突破。因此,本文就给大家介绍一下最近几年 SQL 如何在各个领域乘风破浪!

00e5f71c5592eb88f3d8f25a9b9d382c.png

如果你认为 SQL 就是简单的增删改查(INSERT、SELECT、UPDATE、DELETE),那么你了解的仅仅是 1992 年的SQL。

如果你了解通用表表达式(CTE)和递归查询、用户定义类型或者 OLAP 功能,那么你使用的是 1999 年的 SQL。

如果你接触过窗口函数(分析函数)、MERGE(UPSERT)语句或者 XML 数据类型,应该知道这些不过是 2003 年的 SQL。

2006 年的 SQL 已经定义了 SQL 操作 XML 的规范,支持使用 XQuery 同时访问 SQL 数据和 XML 文档。2008 年又增加了 TRUNCATE TABLE 语句、INSTEAD OF 触发器以及 FETCH 子句等功能。

2011 年 SQL 最主要的新功能之一就是增强了对时态数据库(Temporal database)的支持,可以用于记录那些随着时间而变化的历史数据值,应用领域包括金融、保险、预订系统、医疗信息管理系统等。目前,MariaDB、Oracle、PostgreSQL、Microsoft SQL Server 在一定程度上实现了某些时态表功能,国内的腾讯 TDSQL 是一个全时态数据库系统。

时间来到了 2016 年,SQL 标准又增加了几个重要的功能,首先就是对 JSON 文档的支持。

80cbc6ae45efb866cfae2545f92223ea.png

SQL 与文档数据库

文档数据库属于 NoSQL 的一种,具有模式自由的存储特性,通常采用 JSON 格式进程数据的存储。常用的文档数据库包括 MongoDB、CouchDB 等。

实际上,2016 年 SQL 标准就已经增加了 JSON 功能的支持,包括:

  • JSON 对象的存储与检索;

  • 将 JSON 对象表示成 SQL 数据;

  • 将 SQL 数据表示成 JSON 对象。

这些功能可以表示为以下示意图:

ae48b4e305e05c6b6b18c17ed4060cad.png

如今,主流的关系数据库也都增加了原生 JSON 数据类型和相关函数的支持,包括 Oracle、MySQL、SQL Server、PostgreSQL 等。

7f94fee1553c0a991fc224b9aae7ba8a.png

我们以 MySQL 为例,演示一下如何使用 SQL 查询 JSON 数据。

select emp_id,

emp_info,

emp_info->'$.emp_name' emp_name,

emp_info->'$.sex' sex,

emp_info->>'$.income[0].salary' salary

from employee_json

limit 3;



emp_id|emp_info|emp_name|sex|salary |

------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|-------|

1|{"sex": "男
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值