The JSON field type does not have its own index in the current version, so it is very terrible in production. The efficiency of adding, deleting, modifying, and checking JSON fields can be imagined, and it is basically unusable. Maybe it is based on this. MySQL5.7 provides a Generated field type, which is called generated column or calculated column on the Internet. Let’s first understand what Generated Column is.
1. Introduction to Generated Column
Generated Column is a new feature introduced in MySQL 5.7.6. The so-called Centerated Column means that this column in the database is calculated from other columns. To illustrate, quote the example in the official reference manual:
CREATE TABLE triangle ( sidea DOUBLE, sideb DOUBLE, sidec DOUBLE AS (SQRT(sidea * sidea + sideb * sideb)) ); INSERT INTO triangle (sidea, sideb) VALUES(1,1),(3,4),(6,8); mysql> SELECT * FROM triangle; +-------+-------+--------------------+ | sidea | sideb | sidec | +-------+-------+--------------------+ | 1 | 1 | 1.4142135623730951 | | 3 | 4 | 5 | | 6 | 8 | 10 | +-------+-------+--------------------+
There are two types of Generated Column, namely Virtual Generated Column and Stored Generated Column. The former only saves Generated Column in the data dictionary (metadata of the table), and This column of data will not be persisted to disk; the latter will persist the Generated Column to disk instead of calculating it each time it is read. Obviously, the latter stores data that can be calculated from existing data, requires more disk space, and has no advantage over Virtual Column. Therefore, in MySQL 5.7, the type of Generated Column is not specified, and the default is Virtual Column. Although Virtal Generated Column should generally be used, there are currently many restrictions on using Virtual Generated Column: it cannot be used as a primary key, cannot be used as a primary key, cannot create full-text indexes and spatial indexes, etc., but it may be supported in subsequent versions. Therefore, if you use Generated Column fields for indexing, you should use Stored Generated Column. When using Generated Column for indexing, the official solution for JSON field indexing is to use Stored Generated Column. The table creation statement using Stored Generated Column is as follows, just adding a word:
CREATE TABLE triangle ( sidea DOUBLE, sideb DOUBLE, sidec DOUBLE AS (SQRT(sidea * sidea + sideb * sideb) STORED) );
2. Notes on Generated Column
Generated Column cannot be written, it is automatically generated; When creating, you must consider whether the calculation formula of this column is reasonable. If it is unreasonable, no error will be reported when creating it, but an error will be reported when inserting a value when using it. The columns that Generated Column depends on will prompt an error when deleting, and Generated Column must be deleted first. Only then can we delete the columns it depends on; the definition of Generated Column is illegal. For example, if we define generated column as "column x + column y", it is obvious that column x or column y are both numerical. If we define column x or column y If the column is defined (or modified) as character type, an error is expected, but in fact we can create it normally, but an error will be reported when inserting.
3. Use Generated Column to add an index to the JSON field
Normally, the query related to the JSON field scans the entire table, because the JSON field itself If the index cannot be created, we use the Generated Column feature to generate columns for the relevant keys in the JSON field as Generated Column, and then index the Generated Column:
ALTER TABLE json_test ADD COLUMN age INT AS (JSON_EXTRACT(user_info,'$.age')) STORED, ADD KEY idx_age (age);
The before and after comparison is as follows:
#It can be clearly seen that after using Generated Column and adding an index, the index is used to query the value in the JSON field.
Conclusion
The emergence of Generated Column and JSON Column in MySQL5.7 makes it possible to replace NoSQL such as MongoDB in some scenarios, although overall it has not been done by MongoDB and others. is so powerful, but I believe that there will be more and more scenarios in which these two types are used in the future. At the same time, the challenges to DBA will also become greater and greater. It is hoped that intensive use of JSON type business will be run using independent MySQL instances to prevent JSON from becoming a large field. (The size of the JSON column stored in the JSON document is limited to the value of the max_allowed_packet system variable) This has an impact on other operations.
The above is the content of MySQL 5.7 new features | Json Column and Generated Column (Part 2). For more related content, please pay attention to the PHP Chinese website (www.php.cn)!

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SublimeText3 Linux new version
SublimeText3 Linux latest version
