内容
活动
关注

MySQL · 引擎特性 · 像NOSQL那样使用MySQL

简介: 前言 最近Release的MySQL5.7.12增加了新的协议支持,通过X Plugin实现,同时增加了新的客户端API,开发者可以通过API来把MySQL作为document store的服务端,可以完成和MongoDB类似的document操作,例如支持CRUD等操作,但底层存储依然支持传统数

前言

最近Release的MySQL5.7.12增加了新的协议支持,通过X Plugin实现,同时增加了新的客户端API,开发者可以通过API来把MySQL作为document store的服务端,可以完成和MongoDB类似的document操作,例如支持CRUD等操作,但底层存储依然支持传统数据库的ACID,操作本身在底层也被扩展成标准SQL。从目前的MySQL来看,NOSQL和传统数据库的界限越来越小。目前这个特性还未Production Ready,建议仅用于测试环境。


本文只是记录下学习过程的笔记,不涉及任何内核实现知识。

相关概念

JSON
MySQL从5.7开始支持相对完整的JSON,并开发了完整的JSON函数(WL#7909)

Generated Column
通过表达式的方式来定义列,可以是虚拟的(查询时计算),也可以是物理存储的(DML时变更到文件)

Document
document存储的是一堆key-value的集合,通常使用JSON来进行描述。

Colllection
用于存储Document的容器,在MySQL里表现为一张普通的InnoDB表, 每行存储一个document

CRUD操作
即四种对Document的操作,包括CREATE, READ, UPDATE, DELETE

X PLUGIN及X PROTOCOL
X PLUGIN是官方新引入的插件,需要显式安装到服务器上,主要用于处理来自X协议的请求。用户通过X DevAPI发送基于X Protocol的请求到服务器端,请求可以是异步的,也可以是同步的。

准备工作

安装:

  1. 手动编译安装MySQL5.7.12
  2. 需要安装protobuf库: yum install protobuf
  3. 下载新的命令行shell并安装
  4. 启动MySQL,并安装X Plugin: INSTALL PLUGIN mysqlx SONAME 'mysqlx.so'

文档学习

  1. X DevAPI用户手册
  2. 新的命令行Shell文档
  3. 官方文档
  4. 官方Youtube视频
  5. X Plugin的Worklog WL#8338
  6. 官方博客系列文章:

以下所有的操作API你都可以从官方的文档上获取到

登录

当前shell支持三种模式:JavaScript,Python以及传统的SQL模式。对于SQL模式,你需要在启动客户端时指定--sql,如果不指定,则默认登录模式为javascript

$mysqlsh -S /u01/my57/run/mysql.sock --sql -usb test Creating a Node Session to sb@localhost:33060/test Enter password: Default schema `test` accessible through db ... 然后从sql模式可以切换到别的模式: mysql-sql> select database(); +------------+ | database() | +------------+ | test | +------------+ 1 row in set (0.00 sec) mysql-sql> \py Switching to Python mode... mysql-py>session.sql("select database()"); +------------+ | database() | +------------+ | test | +------------+ 1 row in set (0.00 sec) mysql-py>\js Switching to JavaScript mode... mysql-js> session.sql("select database()"); +------------+ | database() | +------------+ | test | +------------+ 1 row in set (0.00 sec) 

下文我们以javascript为例进行阐述。

schema操作

schema在MySQL里对应的就是一个database,包含操作如下:

/* 创建Schema */ mysql-js> session.getSchemas() { "information_schema": <Schema:information_schema>, "mysql": <Schema:mysql>, "performance_schema": <Schema:performance_schema> } mysql-js> session.createSchema('sb1') <Schema:sb1> mysql-js> session.createSchema('sb2') <Schema:sb2> mysql-js> session.getSchemas() { "information_schema": <Schema:information_schema>, "mysql": <Schema:mysql>, "performance_schema": <Schema:performance_schema>, "sb1": <Schema:sb1>, "sb2": <Schema:sb2> } mysql-js> session.createSchema('test') <Schema:test> /* 删除Schema */ mysql-js> session.dropSchema('sb1') Query OK, 0 items affected (0.00 sec) mysql-js> session.dropSchema('sb2') Query OK, 0 items affected (0.00 sec) 

Collection操作

相关操作:

mysql-js> db <Schema:test> mysql-js> db = session.getSchema('test') <Schema:test> /* 创建Collection */ mysql-js> db.createCollection("sbtest1") <Collection:sbtest1> mysql-js> db.createCollection("sbtest2") <Collection:sbtest2> /* 获取Collection */ mysql-js> db.getCollections() { "sbtest1": <Collection:sbtest1>, "sbtest2": <Collection:sbtest2> } /* 获取某个collection */ mysql-js> db.getCollection("sbtest1"); <Collection:sbtest1> mysql-js> coll=db.getCollection("sbtest1"); <Collection:sbtest1> mysql-js> coll.find() Empty set (0.00 sec) mysql-js> coll.add({Name: "zhai weixiang"}); Query OK, 1 item affected (0.00 sec) mysql-js> coll.find() [ { "Name": "zhai weixiang", "_id": "944d76235812e611c867200bc7293cfa" } ] 1 document in set (0.00 sec) /* 删除Collection */ mysql-js> session.dropCollection('test','sbtest2'); Query OK (0.00 sec) mysql-js> db.getCollections(); { "sbtest1": <Collection:sbtest1> } 

所谓的collection,在物理存储上就是一张普通的InnoDB表,并且这些表具有相同的表定义

mysql> show tables; +----------------+ | Tables_in_test | +----------------+ | sbtest1 | | sbtest2 | +----------------+ 2 rows in set (0.00 sec) mysql> show create table sbtest1\G *************************** 1. row *************************** Table: sbtest1 Create Table: CREATE TABLE `sbtest1` ( `doc` json DEFAULT NULL, `_id` varchar(32) GENERATED ALWAYS AS (json_unquote(json_extract(`doc`,'$._id'))) STORED NOT NULL, UNIQUE KEY `_id` (`_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 1 row in set (0.00 sec)

这个自动创建的表上包含两列:doc列的类型为JSON,另一个列为generated column, 从document的_id上提取。_id由MySQL自动生成,你可以显式指定,但需要保证唯一性。

document操作

完整的CRUD的执行见官方文档图示,以下仅尝试了下简单的操作

/* 创建document */ mysql-js> db = session.getSchema('test') <Schema:test> mysql-js> coll=db.getCollection("sbtest1"); <Collection:sbtest1> mysql-js> coll.add({Name: "zhai weixiang"}); Query OK, 1 item affected (0.00 sec) mysql-js> coll.find() [ { "Name": "zhai weixiang", "_id": "da3f9cb56712e61154d7200bc7293cfa" } ] 1 document in set (0.00 sec) mysql-js> coll.add({'name': 'zhai', 'age': 18}) Query OK, 1 item affected (0.00 sec) mysql-js> coll.add([ {'name': 'zhaiwx', 'age': 17},{'name': 'zhaiweixiang', 'age': 16} ]) Query OK, 2 items affected (0.00 sec) mysql-js> coll.find() [ { "_id": "4ccd04526812e61154d7200bc7293cfa", "age": 16, "name": "zhaiweixiang" }, { "_id": "b2cb04526812e61154d7200bc7293cfa", "age": 17, "name": "zhaiwx" }, { "_id": "c84e9a3c6812e61154d7200bc7293cfa", "age": 18, "name": "zhai" }, { "Name": "zhai weixiang", "_id": "da3f9cb56712e61154d7200bc7293cfa" } ] 4 documents in set (0.00 sec) /* 查询Document */ mysql-js> coll.find('age < 18') [ { "_id": "4ccd04526812e61154d7200bc7293cfa", "age": 16, "name": "zhaiweixiang" }, { "_id": "b2cb04526812e61154d7200bc7293cfa", "age": 17, "name": "zhaiwx" } ] 2 documents in set (0.00 sec) /* 更新Document */ mysql-js> coll.modify("name = 'zhaiweixiang'").set("age",22) Query OK, 1 item affected (0.00 sec) mysql-js> coll.find("name = 'zhaiweixiang'") [ { "_id": "4ccd04526812e61154d7200bc7293cfa", "age": 22, "name": "zhaiweixiang" } ] 1 document in set (0.00 sec) /* 删除Document */ mysql-js> coll.remove("name = 'zhaiweixiang'") Query OK, 1 item affected (0.00 sec) mysql-js> coll.find("name = 'zhaiweixiang'") Empty set (0.00 sec) /* 创建索引 */ mysql-js> coll.createIndex("_age").field("age", "INTEGER", false).execute() Query OK (0.19 sec) /*上述语句在服务器端执行时转换成SQL: ALTER TABLE `test`.`sbtest1` ADD COLUMN ` $ix_i_F177B50B40803DD7D3962E25071AC5CAA3D1139C` INTEGER GENERATED ALWAYS AS (JSON_EXTRACT(doc, '$.age')) VIRTUAL , ADD INDEX `_age` (` $ix_i_F177B50B40803DD7D3962E25071AC5CAA3D1139C`) 会创建出一个虚拟列,并基于其上建立二级索引 */ /* 删除索引,会将索引和虚拟列同时删除 */ mysql-js> coll.dropIndex("_age").execute() Query OK (0.18 sec) /* 支持事务操作,可以通过如下3个接口开启、提交、回滚事务 */ mysql-js> session.startTransaction() Query OK, 0 items affected (0.00 sec) mysql-js> session.commit() Query OK, 0 items affected (0.00 sec) mysql-js> session.rollback() Query OK, 0 items affected (0.00 sec) 

关系表操作

除了操作JSON外,你还可以通过新的命令行shell来进行其他表的操作。

/* 在普通的终端下创建一张表 */ create table t1 (a int, b int); /* 查询表 */ mysql-js> tb = db.getTable('t1') <Table:t1> /* 插入数据 */ mysql-js> tb.insert().values(1,2) Query OK, 1 item affected (0.00 sec) mysql-js> tb.insert('a','b').values(2,3) Query OK, 1 item affected (0.01 sec) /* 查询数据 */ mysql-js> tb.select(['a', 'a + b']).where ('b < :b').bind('b',10).execute() +---+-------------+ | a | (`a` + `b`) | +---+-------------+ | 1 | 3 | | 2 | 5 | +---+-------------+ 2 rows in set (0.00 sec) /** 实际在服务器端执行的SQL为 SELECT `a`,(`a` + `b`) FROM `test`.`t1` WHERE (`b` < 10) */ 
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
2月前
|
SQL 存储 关系型数据库
MySQL内存引擎:Memory存储引擎的适用场景
MySQL Memory存储引擎将数据存储在内存中,提供极速读写性能,适用于会话存储、临时数据处理、高速缓存和实时统计等场景。但其数据在服务器重启后会丢失,不适合持久化存储、大容量数据及高并发写入场景。本文深入解析其特性、原理、适用场景与限制,并提供性能优化技巧及替代方案比较,助你合理利用这一“内存闪电”。
|
2月前
|
SQL 监控 关系型数据库
MySQL事务处理:ACID特性与实战应用
本文深入解析了MySQL事务处理机制及ACID特性,通过银行转账、批量操作等实际案例展示了事务的应用技巧,并提供了性能优化方案。内容涵盖事务操作、一致性保障、并发控制、持久性机制、分布式事务及最佳实践,助力开发者构建高可靠数据库系统。
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
2月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
2月前
|
存储 关系型数据库 MySQL
介绍MySQL的InnoDB引擎特性
总结而言 , Inno DB 引搞 是 MySQL 中 高 性 能 , 高 可靠 的 存 储选项 , 宽泛 应用于要求强 复杂交易处理场景 。
86 15
|
2月前
|
关系型数据库 MySQL 数据库
MySql事务以及事务的四大特性
事务是数据库操作的基本单元,具有ACID四大特性:原子性、一致性、隔离性、持久性。它确保数据的正确性与完整性。并发事务可能引发脏读、不可重复读、幻读等问题,数据库通过不同隔离级别(如读未提交、读已提交、可重复读、串行化)加以解决。MySQL默认使用可重复读级别。高隔离级别虽能更好处理并发问题,但会降低性能。
113 0
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
|
6月前
|
存储 SQL 缓存
mysql数据引擎有哪些
MySQL 提供了多种存储引擎,每种引擎都有其独特的特点和适用场景。以下是一些常见的 MySQL 存储引擎及其特点:
170 0
|
11月前
|
SQL 安全 关系型数据库
【MySQL基础篇】事务(事务操作、事务四大特性、并发事务问题、事务隔离级别)
事务是MySQL中一组不可分割的操作集合,确保所有操作要么全部成功,要么全部失败。本文利用SQL演示并总结了事务操作、事务四大特性、并发事务问题、事务隔离级别。
4691 56
【MySQL基础篇】事务(事务操作、事务四大特性、并发事务问题、事务隔离级别)
|
11月前
|
存储 关系型数据库 MySQL
MySQL引擎InnoDB和MyISAM的区别?
InnoDB是MySQL默认的事务型存储引擎,支持事务、行级锁、MVCC、在线热备份等特性,主索引为聚簇索引,适用于高并发、高可靠性的场景。MyISAM设计简单,支持压缩表、空间索引,但不支持事务和行级锁,适合读多写少、不要求事务的场景。
199 9

相关产品

  • 云数据库 RDS MySQL 版
  • 推荐镜像

    查看更多
    下一篇