Storage Engines¶
https://dev.mysql.com/doc/refman/5.7/en/storage-engines.html
 Compare: Table 15.1 Storage Engines Feature Summary
| Feature | MyISAM | Memory | InnoDB | Archive | NDB | 
|---|---|---|---|---|---|
| Storage limits | 256TB | RAM | 64TB | None | 384EB | 
| Transactions | No | No | Yes | No | Yes | 
| Locking granularity | Table | Table | Row | Row | Row | 
| MVCC | No | No | Yes | No | No | 
| Geospatial data type support | Yes | No | Yes | Yes | Yes | 
| Geospatial indexing support | Yes | No | Yes[a] | No | No | 
| B-tree indexes | Yes | Yes | Yes | No | No | 
| T-tree indexes | No | No | No | No | Yes | 
| Hash indexes | No | Yes | No[b] | No | Yes | 
| Full-text search indexes | Yes | No | Yes[c] | No | No | 
| Clustered indexes | No | No | Yes | No | No | 
| Data caches | No | N/A | Yes | No | Yes | 
| Index caches | Yes | N/A | Yes | No | Yes | 
| Compressed data | Yes[d] | No | Yes[e] | Yes | No | 
| Encrypted data[f] | Yes | Yes | Yes | Yes | Yes | 
| Cluster database support | No | No | No | No | Yes | 
| Replication support[g] | Yes | Limited[h] | Yes | Yes | Yes | 
| Foreign key support | No | No | Yes | No | Yes[i] | 
| Backup / point-in-time recovery[j] | Yes | Yes | Yes | Yes | Yes | 
| Query cache support | Yes | Yes | Yes | Yes | Yes | 
| Update statistics for data dictionary | Yes | Yes | Yes | Yes | Yes | 
CREATE TABLE t1 (i INT) ENGINE = INNODB;
InnoDB: default in MySQL 5.7. 
    transaction-safe (ACID compliant):commit, rollback, and crash-recovery
    row-level locking (without escalation to coarser granularity locks) 
    Oracle-style consistent nonlocking reads
    clustered indexes to reduce I/O for common queries based on primary keys
    FOREIGN KEY referential-integrity constraints
MyISAM: 
    Table-level locking. 
    often used in read-only or read-mostly workloads.
Merge: 
    logically group a series of identical MyISAM tables and reference them as one object.     
Memory or HEAP:
    Its use cases are decreasing:
        InnoDB with its buffer pool memory area
        NDBCLUSTER provides fast key-value lookups for huge distributed data sets
NDB or NDBCLUSTER: highest possible degree of uptime and availability.
Federated: link separate MySQL servers to create one logical database
CSV: Its tables are really text files with comma-separated values.
Archive: compact, unindexed tables
Blackhole: 
    not store data, Queries always return an empty set. 
    can be used in replication configurations
Example: illustrates how to begin writing new storage engines.
MySQL Cluster¶
http://severalnines.com/blog/mysql-docker-introduction-docker-swarm-mode-and-multi-host-networking
 https://dev.mysql.com/doc/refman/5.7/en/mysql-cluster-ndb-innodb-engines.html
JSON¶
MySQL 5.7+¶
https://dev.mysql.com/doc/refman/5.7/en/json.html
CREATE TABLE t1 (jdoc JSON);
INSERT INTO t1 VALUES('{"key1": "value1", "key2": "value2"}');
SELECT JSON_ARRAY('a', 1, NOW());
SELECT JSON_OBJECT('key1', 1, 'key2', 'abc');
SELECT JSON_MERGE('["a", 1]', '{"key": "value"}');
SET @j = JSON_OBJECT('key', 'value');
SELECT @j;
# escape quote character
'{"mascot": "... \\"Sakila\\"."}'
JSON_OBJECT("mascot", "... \"Sakila\".")
JSON_OBJECT('mascot', '... "Sakila".')    # NO_BACKSLASH_ESCAPES
# JSON values is case sensitive
SELECT CAST('null' AS JSON); # `null`, `true`, and `false` always lowercase
SELECT col->"$.mascot" FROM qtest;          # "... \"Sakila\"."
SELECT sentence->>"$.mascot" FROM facts;    # ... "Sakila".
ORDER BY CAST(JSON_EXTRACT(jdoc, '$.id') AS UNSIGNED)
MariaDB 10.2+¶
https://mariadb.com/resources/blog/json-mariadb-102
CREATE TABLE products(id INTEGER NOT NULL PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(255) NOT NULL,
price DECIMAL(9,2) NOT NULL,
stock INTEGER NOT NULL,
attr VARCHAR(1024),
CHECK (attr IS NULL OR JSON_VALID(attr)));
INSERT INTO products VALUES(NULL, 'Blouse', 17, 15, '{"colour": "white"}');
UPDATE products SET attr = JSON_REPLACE(attr, '$.colour', 'red') WHERE name = 'Blouse';
ALTER TABLE products ADD attr_colour VARCHAR(32) AS (JSON_VALUE(attr, '$.colour'));
CREATE INDEX products_attr_colour_ix ON products(attr_colour);
EXPLAIN SELECT * FROM products WHERE attr_colour = 'white';     # verify index