当前位置: 首页 > news >正文

MySQL也开始支持JavaScript了

2023 年 12 月 16 日,Oracle 公司在一篇名为 《Introducing JavaScript support in MySQL》的文章中宣布 MySQL 数据库服务器将开始支持 JavaScript 语言。

这个举措标志着继PostgreSQL之后, MySQL 也支持使用 JavaScript 编写函数和存储过程了。作为最流行的开源数据库,这一消息在技术界引起了广泛关注。

PostgreSQL 通过其PL/v8扩展自 2012 年起就已经支持 JavaScript​​​​​​​。当前所有版本均支持 PLV8,包括像 Amazon RDS 这样的托管服务,并可用在存储过程和触发器中。

这一新功能目前仅在 MySQL 企业版和 MySQL Heatwave 中提供,并处于预览阶段。开发人员现在可以在 MySQL 数据库服务器中编写 JavaScript 存储过程(函数和过程)。存储的程序将与 GraalVM 运行时一起运行。

*存储过程(Stored Procedure)

存储过程是一种在数据库中存储复杂程序,以便外部程序调用的一种数据库对象。存储过程是为了完成特定功能的 SQL 语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。MySQL 5.0 版本开始支持存储过程。

为什么使用 JavaScript 存储过程?

JavaScript 是最流行的编程语言之一,除了更简单的语法和对现代语言特性的支持外,它受欢迎的一个关键因素是丰富的生态系统,它在浏览器、服务端、客户端等场景提供了大量可重用的代码模块。

当需要持久存储时,最流行的开源数据库 MySQL 将是 JavaScript 开发人员的自然选择。通过在存储过程中支持 JavaScript,开发人员将能够用熟悉的语言编写 MySQL 存储过程,并利用广泛的 JavaScript 生态系统。

对 JavaScript 存储过程的支持,不仅会通过利用大型生态系统来提高开发人员的生产力;现在,更多的开发人员将拥有编写存储过程的必要技能。换句话说,公司企业现在可以利用广泛访问的 JavaScript 技能集进行后端开发,从而挖掘更广泛的开发人员人才。

存储过程最大限度地减少了数据库服务器和应用程序之间的数据移动,从而提供了一个关键优势。

传输大量数据,特别是批处理数据,可能会出现问题,原因有很多:

  • 这是非常耗时的,并且可能会导致大量的网络开销。
  • 当应用程序进行频繁交互时,延迟的增加可能会变得明显。
  • 在中间层或应用层处理大数据量需要大量的内存和存储,增加了成本。
  • 由于安全风险和数据保护需求,通常必须避免机器之间的数据传输,特别是在云环境中。
  • 将大量数据移出数据库服务将增加出口成本。

使用存储过程在数据库内部处理数据是解决这些问题的常见方法。

p-01

使用场景

MySQL-JavaScript 在应用程序设计中释放了新的机会,这些机会曾经受到权衡的限制。JavaScript 存储过程使开发人员能够轻松地避开数据移动,并在数据库中无缝地实现高级数据处理逻辑。下面列出了一些简单用例的例子:

  • 数据提取: 从数据库中常用的复杂对象中提取信息,如 URL 字符串。
  • 数据格式化: 使用广泛使用的模板方案(如 JavaScript Mustache 包)生成格式化字符串。
  • 近似搜索: 在 SELECT 查询中使用相似性评分函数,例如,从表中检索相似的字符串。
  • 数据验证: 使用复杂的验证规则清理数据。例如,使用 JavaScript 验证器包。
  • 压缩/编码: 使用自定义算法,不包含在 MySQL 中,用于数据压缩和加密。
  • 数据转换: 更改数据表示,例如将字符串列转换为特征工程中使用的稀疏矩阵表示。

所提供的示例只是对该特性潜力的一瞥。还有更复杂的用例,比如部署完整的数据管道和为机器学习应用程序设置登台环境。

MySQL-JavaScript

MySQL 正在引入对 JavaScript 存储过程的支持。用户现在可以在数据库中表达丰富的过程逻辑。JavaScript 运行时是通过 GraalVM 集成的,用户可以使用 GraalVM 的所有企业版(EE)功能,如编译器优化、性能和安全功能,而不需要额外的费用。

此版本支持:

  • 基于ECMAScript 2021的 js 语言
  • 存储过程和存储函数
  • MySQL 数据类型,如所有的整数、浮点数和 CHAR/VARCHAR 类型的变化

ECMAScript 标准库包括许多基本的使用操作和数据结构,使实现变得简单而富有表现力。开发人员还可以重用来自在线包管理器(如“npm”)的数百万个可用的第三方包。

*GraalVM是一个 Oracle 编译器生态系统,包括 JDK,语言实现,如 JavaScript, R, Python, Ruby 和 Java。它包括即时(JIT)和提前(AOT)编译技术。它还提供了一个完全托管的虚拟机,具有沙箱功能和工具支持。MySQL-JavaScript 与 GraalVM 企业版集成。

定义 JavaScript 存储过程

要在 MySQL 中创建一个 JavaScript 存储过程,您可以使用用于传统存储函数和过程的相同 SQL 语句的变体:

CREATE FUNCTION gcd_js (a INT, b INT) RETURNS INT
LANGUAGE JAVASCRIPT AS $$let [x, y] = [Math.abs(a), Math.abs(b)];while(y) [x, y] = [y, x % y];return x;$$;

从上面的示例中可以看出,JavaScript 代码直接嵌入到 sql 可调用函数的定义中。参数的名称可以在 JavaScript 代码中直接引用,当调用函数时,SQL 类型和 JavaScript 类型之间会有隐式的类型转换。
要调用 JavaScript 存储过程,应该使用 call 语句,类似于常规的 SQL 存储过程。存储过程支持输入和输出参数。

在 SQL 语句中执行 JavaScript 代码

JavaScript 函数可以在传统 SQL 函数调用的任何地方从 SQL 语句调用;在 SELECT 表达式、WHERE、GROUP BY 和 ORDER BY 子句、dml、ddl、Views 等中。下面是一个 SQL 语句调用我们上面定义的函数的例子:

SELECT col1, col2, gcd_js(col1,col2)
FROM my_table
WHERE gcd_js(col1, col2) > 1
ORDER BY gcd_js(col1, col2);CREATE TABLE gcd_table
AS SELECT gcd_js(col1,col2)
FROM my_table;

在 MySQL 中调试 JavaScript 代码

调试与软件开发是密切相关的。当 JavaScript 程序在数据库中运行时,MySQL-JavaScript 特性公开了额外的 SQL 接口以帮助进行故障排除。

CREATE PROCEDURE division (IN a INT, IN b INT,
OUT result DOUBLE) LANGUAGE JAVASCRIPT AS $$function validate(num) {console.log("validating input value: ", num);if (num === 0) throw ("Division by Zero!");}validate(b);result = a / b;
$$

JavaScript 异常到 MySQL 错误的转换是透明的。除了标准输出,开发人员还可以访问 JavaScript 堆栈跟踪。

CALL division( 5, 0, @res);
ERROR 6000 (HY000): JavaScript> Division by Zero!SELECT mle_session_state("stdout");
validating input value:  0SELECT mle_session_state("stack_trace");
<js> validate(division:9:187-214)
<js> division(division:11:222-232)
<js> :anonymous(division:15:256-265)
</js></js></js>

各项指标

安全性

按 Oracle 宣称,MySQL 中对 JavaScript 的支持提供了最高级别的安全性、隔离性和数据保护。MySQL 的 JavaScript 依赖于业界公认的 Oracle 的 GraalVM 安全保证。

虚拟机沙箱保证了恶意代码无法危害 MySQL 服务器的其他模块。每个存储过程都在它自己的上下文中被解析和执行。此隔离策略不允许一个存储过程读取或修改其他存储过程的数据或代码。从 JavaScript 用户代码中生成或操作线程是受限制的,JavaScript 用户代码不能访问网络通信或文件系统。

JavaScript 存储过程建立在标准 MySQL 特权模型之上。只有特权用户才能创建存储过程。对 SP 的访问也可以通过特权来控制。一个用户可以定义可由其他用户执行的存储过程。

兼容性

JavaScript 存储过程可以与传统的 SQL 存储过程无缝协作。该特性与存储引擎无关,数据可以透明地从 InnoDB、Lakehouse 和 HeatWave 访问。

MySQL 热浪服务现在在 OCI、AWS 和 Azure 服务部署上预装和配置了 JavaScript。对于 MySQL 企业版,该功能需要手动安装和配置。

性能

MySQL-JavaScript 集成为其特定用例使用定制的 VM,以实现最佳的端到端性能。这种定制基于 GraalVM 的提前(AOT)编译,其中语言实现被编译成本机二进制表示,以便快速处理。

GraalVM 有自己的基于 ECMAScript 2021 标准的 JavaScript 实现。该语言的实现在性能上是有竞争力的,尽管它是使用 GraalVM 的 Polyglot 框架实现的,该框架专注于在同一个 VM 中支持多种编程语言。

最后,MySQL-JavaScript 特性受益于 GraalVM 企业版带来的各种最先进的优化,例如编译器优化,包括积极的内联和部分转义分析。它还包括一个配置文件引导的即时(JIT)编译器,该编译器在运行时在解释器和本机编译之间切换。

结论

MySQL- javascript 使开发人员能够直接在 MySQL 服务器中表达复杂的编程逻辑。这允许开发人员将应用程序的数据密集型部分推到数据附近,从而降低数据移动成本。使用基于 ECMAScript 2021 的 JavaScript 可以防止供应商锁定问题,而开发人员无需额外费用即可享受 GraalVM(企业版)的所有好处。要免费试用 MySQL- javascript,请从 Oracle Technology Network (OTN)下载 MySQL 企业版。MySQL- javascript 还与 MySQL HeatWave 云服务无缝集成,开发人员只需动动指尖即可获得最新的创新。

另外,有关 MySQL 对 JavaScript 支持的详细描述文档可以见:https://downloads.mysql.com/docs/mysql-manual-js-preview.en.pdf

作者联系方式

michealwayne@163.com
GitHub:http://github.com/MichealWayne


相关链接
  • Oracle 《Introducing JavaScript support in MySQL》:https://blogs.oracle.com/mysql/post/introducing-javascript-support-in-mysql
  • Oracle 《MySQL 8.3 Reference Manual——JavaScript Programs Technology Preview》:https://downloads.mysql.com/docs/mysql-manual-js-preview.en.pdf
  • InfoQ 《MySQL 支持 JavaScript,目前处于预览阶段》:https://www.infoq.cn/article/6bT6kDa1ADuCKeTU4VlI
  • code 秘密花园 《MySQL 正式引入 JavaScript 支持!》:https://mp.weixin.qq.com/s/5XGhgs5PI9RPwHD0RjbroA

相关文章:

MySQL也开始支持JavaScript了

2023 年 12 月 16 日&#xff0c;Oracle 公司在一篇名为 《Introducing JavaScript support in MySQL》的文章中宣布 MySQL 数据库服务器将开始支持 JavaScript 语言。 这个举措标志着继PostgreSQL之后&#xff0c; MySQL 也支持使用 JavaScript 编写函数和存储过程了。作为最…...

百度大脑 使用

百度大脑&#xff1a; 官方网址&#xff1a;https://ai.baidu.com/ 文档中心&#xff1a;https://ai.baidu.com/ai-doc 体验中心&#xff1a;https://ai.baidu.com/experience 百度大脑则是百度AI核心技术引擎&#xff0c;它包括基础层、感知层、认知层和安全&#xff0c;是百…...

Spring Boot 中的外部化配置

Spring Boot 中的外部化配置 一、配置文件基础1.配置文件格式&#xff08;1&#xff09;YAML 基本语法规则&#xff08;2&#xff09;YAML 支持三种数据结构 2.application 文件3.application.properties 配置文件4.application.yml 配置文件5.Environment6.组织多文件7.多环境…...

10个常考的前端手写题,你全都会吗?(下)

前言 &#x1f4eb; 大家好&#xff0c;我是南木元元&#xff0c;热爱技术和分享&#xff0c;欢迎大家交流&#xff0c;一起学习进步&#xff01; &#x1f345; 个人主页&#xff1a;南木元元 今天接着上篇再来分享一下10个常见的JavaScript手写功能。 目录 1.实现继承 ES5继…...

Java 面试题库

基础篇 面向对象的特征 封装&#xff08;Encapsulation&#xff09;&#xff1a; 封装是指将对象的数据&#xff08;属性&#xff09;和行为&#xff08;方法&#xff09;结合在一起&#xff0c;形成一个独立的实体。对象的数据被隐藏在内部&#xff0c;只能通过定义好的接口&…...

仿真机器人-深度学习CV和激光雷达感知(项目2)day6【数学基础-坐标变换】

文章目录 前言坐标变换的作用旋转与平移二维变换旋转平移推广到三维齐次坐标问题引入定义用法变换矩阵旋转的其他表示方法*前言 💫你好,我是辰chen,本文旨在准备考研复试或就业 💫本文内容是我为复试准备的第二个项目 💫欢迎大家的关注,我的博客主要关注于考研408以及…...

Android下载gradle失败解决方法

1、在gradle-wrapper.properties文件中查看自己需要下载gradle什么版本的包和zip路径&#xff08;wrapper/dists&#xff09;。 2、在setting中查看Gradle的保存路径&#xff0c;如下图&#xff1a;C:/Users/Administrator/.gradle&#xff0c;加上第一步的zip路径得到下载grad…...

C#,最小生成树(MST)克鲁斯卡尔(Kruskal)算法的源代码

一、Kruskal算法简史 克鲁斯卡尔&#xff08;Kruskal&#xff09;算法是一种用来寻找最小生成树的算法&#xff0c;由Joseph Kruskal在1956年发表。用来解决同样问题的还有Prim算法和Boruvka算法等。三种算法都是贪婪算法的应用。和Boruvka算法不同的地方是&#xff0c;Kruska…...

Oracle篇—参数文件在11gRAC或12cRAC的启动位置介绍

☘️博主介绍☘️&#xff1a; ✨又是一天没白过&#xff0c;我是奈斯&#xff0c;DBA一名✨ ✌✌️擅长Oracle、MySQL、SQLserver、Linux&#xff0c;也在积极的扩展IT方向的其他知识面✌✌️ ❣️❣️❣️大佬们都喜欢静静的看文章&#xff0c;并且也会默默的点赞收藏加关注❣…...

scrapy pipelines

1.时间的处理 获取当前时间的字符串 # 创建一个datetime对象并设置为当前时间&#xff0c;该时间少8小时 dt datetime.datetime.now() # 将datetime转换为本地时区 local_tz pytz.timezone(Asia/Shanghai) local_dt local_tz.localize(dt) # 将datetime对象格式化为ISO 86…...

element-ui 打包流程源码解析——babel 相关

目录 1&#xff0c;babel-cli2&#xff0c;babel-core3&#xff0c;.babelrc3.1&#xff0c;presets3.2&#xff0c;plugins其他相关 该文章是为了更好的理解&#xff1a;element-ui 打包流程源码解析&#xff08;上&#xff09; 第2.5节 npm run build:utils 打包命令 "…...

听神经瘤的听力学表现

听神经瘤的听力学诊断 听神经瘤的听力学表型多样&#xff0c;听力正常者不能排除听神经瘤&#xff1b;听力损失程度不能预判肿瘤大小&#xff1b;纯音测听与言语识别率不一致应警惕蜗后病变&#xff1b;听性脑干诱发电位诊断听神经瘤敏感度随肿瘤增大而增加。 一&#xff0e;纯…...

C#用DateTime.Now静态属性返回日期的星期信息

目录 一、使用的方法 1.Now属性 2.ToString方法 二、示例 使用DateTime结构的Now静态属性&#xff0c;可以方便地获取系统日期信息。调用时间对象的ToString方法&#xff0c;在该方法的参数中添加适当的格式化字符串&#xff0c;将返回日期的星期信息。 一、使用的方法 1…...

ARMv8-AArch64 的异常处理模型详解之异常类型 Exception types

异常类型详解 Exception types 一&#xff0c; 什么是异常二&#xff0c;同步异常&#xff08;synchronous exceptions&#xff09;2.1 无效的指令和陷阱异常&#xff08;Invalid instructions and trap exceptions&#xff09;2.2 内存访问产生的异常2.3 产生异常的指令2.4 调…...

Linux操作系统概念

绪论​&#xff1a; “心灵纯洁的人&#xff0c;生活充满甜蜜和喜悦。——列夫托尔斯泰”&#xff0c;本章的主要内容是介绍了硬件的组成结构冯诺依曼体系结构以及操作系统的概念和操作系统的作用&#xff0c;本章的内容主要是理论他起到承上启下的作用只有理解了操作系统的运行…...

Speech | 人工智能中关于语音务必需要了解的基础知识(信号处理)及代码

语音是指人们讲话时发出的话语&#xff0c;是一种人们进行信息交流的声音&#xff0c;是由一连串的音组成语言的声音&#xff0c;我们可以理解为语音(speech)声音(acoustic)语言(language)。 目录 0.声音的基本属性 0.1.音高(pitch) 0.2.音量(Volume) 0.3.音色(Timbre) 0…...

c# 单例模式实现

方式一&#xff1a; 在C#中&#xff0c;可以使用单例模式来确保一个类只有一个实例&#xff0c;并提供一个全局访问点。 public class Singleton {private static Singleton instance;private static readonly object lockObject new object();private Singleton(){// 私有构…...

万字长文详解Java线程池面试题

王有志&#xff0c;一个分享硬核 Java 技术的互金摸鱼侠 加入 Java 人的提桶跑路群&#xff1a;共同富裕的Java人 今天是《面霸的自我修养》第 6 篇文章&#xff0c;我们一起来看看面试中会问到哪些关于线程池的问题吧。数据来源&#xff1a; 大部分来自于各机构&#xff08;J…...

【jQuery入门】链式编程、修改css、类操作和className的区别

文章目录 前言一、链式编程二、修改css2.1 获取css的值2.2 设置单个css属性2.3 设置类样式添加类移除类切换类 三、类操作与className的区别总结 前言 jQuery是一个流行的JavaScript库&#xff0c;广泛用于简化DOM操作和处理事件。在jQuery中&#xff0c;链式编程是一种强大的…...

使用的uview 微信高版本 头像昵称填写能力

<template><view><button class"cu-btn block bg-blue margin-tb-sm lg" tap"wxGetUserInfo">一键登录</button><view><!-- 提示窗示例 --><u-popup :show"show" background-color"#fff">&…...

地震勘探——干扰波识别、井中地震时距曲线特点

目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波&#xff1a;可以用来解决所提出的地质任务的波&#xff1b;干扰波&#xff1a;所有妨碍辨认、追踪有效波的其他波。 地震勘探中&#xff0c;有效波和干扰波是相对的。例如&#xff0c;在反射波…...

Zustand 状态管理库:极简而强大的解决方案

Zustand 是一个轻量级、快速和可扩展的状态管理库&#xff0c;特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...

JavaScript 中的 ES|QL:利用 Apache Arrow 工具

作者&#xff1a;来自 Elastic Jeffrey Rengifo 学习如何将 ES|QL 与 JavaScript 的 Apache Arrow 客户端工具一起使用。 想获得 Elastic 认证吗&#xff1f;了解下一期 Elasticsearch Engineer 培训的时间吧&#xff01; Elasticsearch 拥有众多新功能&#xff0c;助你为自己…...

如何将联系人从 iPhone 转移到 Android

从 iPhone 换到 Android 手机时&#xff0c;你可能需要保留重要的数据&#xff0c;例如通讯录。好在&#xff0c;将通讯录从 iPhone 转移到 Android 手机非常简单&#xff0c;你可以从本文中学习 6 种可靠的方法&#xff0c;确保随时保持连接&#xff0c;不错过任何信息。 第 1…...

涂鸦T5AI手搓语音、emoji、otto机器人从入门到实战

“&#x1f916;手搓TuyaAI语音指令 &#x1f60d;秒变表情包大师&#xff0c;让萌系Otto机器人&#x1f525;玩出智能新花样&#xff01;开整&#xff01;” &#x1f916; Otto机器人 → 直接点明主体 手搓TuyaAI语音 → 强调 自主编程/自定义 语音控制&#xff08;TuyaAI…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控&#xff0c;故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令&#xff1a;jps [options] [hostid] 功能&#xff1a;本地虚拟机进程显示进程ID&#xff08;与ps相同&#xff09;&#xff0c;可同时显示主类&#x…...

Element Plus 表单(el-form)中关于正整数输入的校验规则

目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入&#xff08;联动&#xff09;2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...

Go 语言并发编程基础:无缓冲与有缓冲通道

在上一章节中&#xff0c;我们了解了 Channel 的基本用法。本章将重点分析 Go 中通道的两种类型 —— 无缓冲通道与有缓冲通道&#xff0c;它们在并发编程中各具特点和应用场景。 一、通道的基本分类 类型定义形式特点无缓冲通道make(chan T)发送和接收都必须准备好&#xff0…...

LOOI机器人的技术实现解析:从手势识别到边缘检测

LOOI机器人作为一款创新的AI硬件产品&#xff0c;通过将智能手机转变为具有情感交互能力的桌面机器人&#xff0c;展示了前沿AI技术与传统硬件设计的完美结合。作为AI与玩具领域的专家&#xff0c;我将全面解析LOOI的技术实现架构&#xff0c;特别是其手势识别、物体识别和环境…...

macOS 终端智能代理检测

&#x1f9e0; 终端智能代理检测&#xff1a;自动判断是否需要设置代理访问 GitHub 在开发中&#xff0c;使用 GitHub 是非常常见的需求。但有时候我们会发现某些命令失败、插件无法更新&#xff0c;例如&#xff1a; fatal: unable to access https://github.com/ohmyzsh/oh…...