MySQL进阶

1、MariaDB or MySQL:简介

(DBMS:Database Managerment System,数据管理系统;
RDBMS即关系数据库管理系统(Relational Database Management System),是将数据组织为相关的行和列的系统,而管理关系数据库的计算机软件就是关系数据库管理系统,常用的数据库软件有Oracle、SQL Server等)
数据库排行

Relational DBMS:RDBMS(以类解决方案)
Oracle
MySQL --> MariaDB
NoSQL:
Document store
Key-value store (eg:Redis)
Wide column store
Graph DBMS
Search engine:倒排索引
Solr
ElasticSearch (ELS 搜索引擎)
Time Series DBMS
InfluxDB

层次模型 --> 网状模型 --> (Codd) 关系模型
DBMS --> RDBMS
RDBMS:
范式:第一范式、第二范式、第三范式;
表:row, column
关系运算:
选择
投影

2、数据库:

表、索引、视图(虚表)、SQL、存储过程、存储函数、触发器、事件调度器;
DDL(数据定义语言):CREATE,ALTER,DROP
DML(数据操控语言):INSERT/UPDATE/DELETE/SELECT
约束:
主键约束:惟一、非空;一张表只能有一个;
惟一键约束:惟一,可以存在多个;
外键约束:参考性约束;
检查性约束:check;
三层模型:
物理层 --> SA
逻辑层 --> DBA
视图层 --> Coder
实现:
Oracle, DB2, Sybase, Infomix, SQL Server;
MySQL, MariaDB, PostgreSQL开源, SQLite;

3、MySQL:

5.1 --> 5.5 --> 5.6 --> 5.7 --> 8.0
MariaDB:5.5.x --> 10.x
特性:
插件式存储引
单进程多线程
安装MySQL
OS Vendor:rpm
MySQL:
source code:cmak
binary package:
i686, x86_64;
glibc VERSION
prepackage:rpm, deb
os, arch,

clipboard1.png

skip_name_resolve 跳过名称解析
innodb_file_per_table 是否使用单独的表空间
max_connection 最大连接数
服务端程序:
mysqld, mysqld_safe, mysqld_multi
客户端程序:

    mysql, mysqldump, mysqlbinlog, mysqladmin, ...
非客户端类管理程序:
    myiamchk, myisampack, ...       
mysqld-5.7
    创建数据目录,属主属组属于运行者用户身份mysql;
    初始化:
        mysqld  --initilize-insecure --basedir=/usr/local/mysql --datadir=/data/mysql --user=mysql
查配置文件路径,修改配置文件:/usr/local/mysql/etc/my.cnf
        datadir
        socket
        includedir
        pid
准备错误日志文件:
         复制启动脚本:/usr/local/mysql/support-files/mysql.server --> /etc/init.d/mysqld
配置文件:
        读取多处的多个配置文件,而且会以指定的次序的进行;   
        # my_print_defaults
            Default options are read from the following files in the given order:
            /etc/mysql/my.cnf  /etc/my.cnf ~/.my.cnf 
        不同的配置文件中出现同一参数且拥有不同值时,后读取将为最终生效值; 
                修改默认读取的配置文件(mysqld_safe命令):
                     --defaults-file=file_name  
                于读取的默认配置文件之外再加载一个文件:    
                    --defaults-extra-file=path                  
配置文件格式:
                 ini风格的配置文件,能够为mysql的各种应用程序提供配置信息:
                [mysqld]
                [mysqld_safe]
                [mysqld_multi]
                [server]
                [mysql]
                [mysqldump]
                [client]
                ...
                PARAMETER = VALUE 
                    PARAMETER:
                        innodb_file_per_table
                        innodb-file-per-table 
程序文件:
    服务端程序:mysqld_safe, mysqld_multi
    客户端程序:mysql, mysqldump, mysqladmin
    工具程序:myisampack, ...
        mysql --> mysql protocol --> mysqld 
        mysql:交互式CLI工具;
        mysql [options] db_name
常用选项:
    --host=host_name, -h host_name:服务端地址;
    --user=user_name, -u user_name:用户名;
    --password[=password], -p[password]:用户密码; 
    --port=port_num, -P port_num:服务端端口; 
    --protocol={TCP|SOCKET|PIPE|MEMORY}:
    本地通信:基于本地回环地址进行请求,将基于本地通信协议;
                Linux:SOCKET
                Windows:PIPE,MEMORY
    非本地通信:使用非本地回环地址进行的请求; TCP协议;
            --socket=path, -S path
            --database=db_name, -D db_name:
            --compress, -C:数据压缩传输
            --execute=statement, -e statement:非交互模式执行SQL语句
            --vertical, -E:查询结果纵向显示;                        
 命令:
   客户端命令:于客户端执行;
   服务端命令:SQL语句,需要一次性完整地发往服务端;语句必须有结束符;
    ?         (\?) Synonym for `help'.
    clear     (\c) Clear the current input statement.
    connect   (\r) Reconnect to the server. Optional arguments are db and host.
    delimiter (\d) Set statement delimiter.
    edit      (\e) Edit command with $EDITOR.
    ego       (\G) Send command to mysql server, display result vertically.
    exit      (\q) Exit mysql. Same as quit.
    go        (\g) Send command to mysql server.
    help      (\h) Display this help.
    nopager   (\n) Disable pager, print to stdout.
    notee     (\t) Don't write into outfile.
    pager     (\P) Set PAGER [to_pager]. Print the query results via PAGER.
    print     (\p) Print current command.
        prompt    (\R) Change your mysql prompt.
    quit      (\q) Quit mysql.
    rehash    (\#) Rebuild completion hash.
    source    (\.) Execute an SQL script file. Takes a file name as an argument.
    status    (\s) Get status information from the server.
    system    (\!) Execute a system shell command.
    tee       (\T) Set outfile [to_outfile]. Append everything into given outfile.
    use       (\u) Use another database. Takes database name as argument.
    charset   (\C) Switch to another charset. Might be needed for processing  
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     binlog with multi-byte charsets.
    warnings  (\W) Show warnings after every statement.
    nowarning (\w) Don't show warnings after every statement.   
                        
mysql命令的使用帮助:
        # man mysql
        # mysql  --help  --verbose
                        
sql脚本运行:
         mysql [options] [DATABASE] < /PATH/FROM/SOME_SQL_SCRIPT

mysqld服务器程序:工作特性的定义方式
                命令行选项
                配置文件参数
                SHOW [GLOBAL | SESSION] VARIABLES [like_or_where]
                
服务器参数/变量:设定MySQL的运行特性;
    mysql> SHOW GLOBAL|[SESSION] VARIABLES [LIKE clause];
         状态(统计)参数/变量:保存MySQL运行中的统计数据或状态数据;
    mysql> SHOW GLOBA|[SESSION] STATUS [LIKE clause];
                    
显示单个变量设定值的方法:
    mysql> SELECT @@[global.|session.]system_var_name
                    
        %:匹配任意长度的任意字符;
        _:匹配任意单个字符;
                    
变量/参数级别:
        全局:为所有会话设定默认; 
        会话:跟单个会话相关;会话建立会从全局继承;          
服务器变量的调整方式:
运行时修改:
        global:仅对修改后新建立的会话有效;
        session:仅对当前会话有效,且立即生效;
启动前通过配置文件修改:
        重启后生效;
                    
运行时修改变量值操作方法:
        mysql> HELP SET         
        SET [GLOBAL | SESSION] system_var_name = expr
        SET [@@global. | @@session. | @@]system_var_name = expr     
        注:GLOBAL值的修改要求用户拥有管理权限;     
安装完成后的安全初始化:
        mysql_secure_installation
运行前常修改的参数:
        innodb_file_per_table=ON
        skip_name_resolve=ON
        ...
SQL:ANSI SQL 
        SQL-86, SQL-89, SQL-92, SQL-99, SQL-03, ...
MySQL的数据类型:
            字符型
            数值型
            日期时间型
            内建类型
            
字符型:
    CHAR(#), BINARY(#):定长型;CHAR不区分字符大小写,而BINARY区分;
    VARCHAR(#), VARBINARY(#):变长型
    TEXT:TINYTEXT,TEXT,MEDIUMTEXT,LONGTEXT
    BLOB:TINYBLOB,BLOB,MEDIUMBLOB, LONGBLOB
数值型:
    浮点型:近似
        FLOAT
        DOUBLE
        REAL
        BIT
        整型:精确
                INTEGER:TINYINT,SMALLINT,MEDIUMINT,INT,BIGINT
                    DECIMAL
            
日期时间型:      
                日期:DATE
        时间:TIME
        日期j时间:DATETIME
        时间戳:TIMESTAMP
        年份:YEAR(2), YEAR(4)
            
内建:
        ENUM:枚举
        ENUM('Sun','Mon','Tue','Wed')
        SET:集合
                    
类型修饰符:
    字符型:NOT NULL,NULL,DEFALUT ‘STRING’,CHARACET SET ‘CHARSET’,COLLATION ‘collocation'
    整型:NOT NULL, NULL, DEFALUT value, AUTO_INCREMENT, UNSIGNED
    日期时间型:NOT NULL, NULL, DEFAULT 
SQL MODE:定义mysqld对约束等违反时的响应行为等设定;
            常用的MODE:
                TRADITIONAL
                STRICT_TRANS_TABLES
                STRICT_ALL_TABLES
                
修改方式:
        mysql> SET GLOBAL sql_mode='MODE';
        mysql> SET @@global.sql_mode='MODE';
                
        SQL:DDL,DML
DDL:(Data Control Language)数据控制语言
    mysql> HELP Data Definition
        CREATE, ALTER, DROP
        DATABASE, TABLE
        INDEX, VIEW, USER
FUNCTION, FUNCTION UDF, PROCEDURE, TABLESPACE, TRIGGER, SERVER 
                    
DML:Data Manipulation Language,数据操纵语言
    mysql> HELP Data Manipulation
        INSERT/REPLACE, DELETE, SELECT, UPDATE
数据库:
    CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name CHARACTER SET [=] charset_name  COLLATE [=] collation_name
    ALTER {DATABASE | SCHEMA} [db_name] CHARACTER SET [=] charset_name  COLLATE [=] collation_name
    DROP {DATABASE | SCHEMA} [IF EXISTS] db_name

4、表:

CREATE
(1) CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
            (create_definition,...)
            [table_options]
            [partition_options]

 CREATE TABLE [IF NOT EXISTS] tble_name (col_name data_typ|INDEX|CONSTRAINT);
            table_options:
            ENGINE [=] engine_name
    查看支持的所有存储引擎:
            mysql> SHOW ENGINES;
    查看指定表的存储引擎:
            mysql> SHOW TABLE STATUS LIKE clause;
                          ROW_FORMAT [=] {DEFAULT|DYNAMIC|FIXED|COMPRESSED|REDUNDANT|COMPACT}
                        
(2) CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
            [(create_definition,...)]
            [table_options]
            [partition_options]
            select_statement
    直接创建表,并将查询语句的结果插入到新创建的表中;
(3) CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
        { LIKE old_tbl_name | (LIKE old_tbl_name) }
    复制某存在的表的结构来创建新的空表;
DROP:
  DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name]; 
ALTER:
ALTER  TABLE tbl_name
        [alter_specification [, alter_specification] ...]
    可修改内容:
        (1) table_options
        (2) 添加定义:ADD
             字段、字段集合、索引、约束
        (3) 修改字段:
           CHANGE [COLUMN] old_col_name new_col_name column_definition [FIRST|AFTER col_name]
    MODIFY [COLUMN] col_name column_definition [FIRST | AFTER col_name]
        (4) 删除操作:DROP
             字段、索引、约束
            表重命名:
                RENAME [TO|AS] new_tbl_name
            查看表结构定义:
                DESC tbl_name;
            查看表定义:
                    SHOW CREATE TABLE tbl_name
            查看表属性信息:
    SHOW TABLE STATUS [{FROM | IN} db_name] [LIKE 'pattern' | WHERE expr]

5、索引:

    创建:
    CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name [index_type] ON tbl_name (index_col_name,...)
    查看:
    SHOW {INDEX | INDEXES | KEYS} {FROM | IN} tbl_name [{FROM | IN} db_name] [WHERE expr]
    删除:
    DROP  INDEX index_name ON tbl_name
        索引类型:
        聚集索引、非聚集索引:索引是否与数据存在一起;
        主键索引、辅助索引
        稠密索引、稀疏索引:是否索引了每一个数据项;
        BTREE(B+)、HASH、R Tree、FULLTEXT
        BTREE:左前缀;
        EXPLAIN:分析查询语句的执行路径;

6、视图:VIEW

        虚表:存储下来的SELECT语句;
    创建:
        CREATE  VIEW view_name [(column_list)] AS select_statement
    修改:
        ALTER  VIEW view_name [(column_list)] AS select_statement
    删除:
        DROP VIEW [IF EXISTS] view_name [, view_name] ...

7、DML:

INSERT/REPLACE,DELETE,UPDATE,SELECT
    INSERT:
                               单行插入
                批量插入
                
INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
        [INTO] tbl_name [(col_name,...)]
        {VALUES | VALUE} ({expr | DEFAULT},...),(...),...
        [ ON DUPLICATE KEY UPDATE
        col_name=expr
        [, col_name=expr] ... ]

    Or:

        INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
                [INTO] tbl_name
                SET col_name={expr | DEFAULT}, ...
                [ ON DUPLICATE KEY UPDATE
                col_name=expr
                    [, col_name=expr] ... ]

                Or:

            INSERT [LOW_PRIORITY | HIGH_PRIORITY] [IGNORE]
                [INTO] tbl_name [(col_name,...)]
                SELECT ...
                [ ON DUPLICATE KEY UPDATE
                col_name=expr
                    [, col_name=expr] ... ]
DELETE:
      DELETE  FROM tbl_name [WHERE where_condition] [ORDER BY ...] [LIMIT row_count]        
        注意:一定要有限制条件,否则将清空整个表;
                限制条件:
                [WHERE where_condition]
                [ORDER BY ...] [LIMIT row_count]
UPDATE:
UPDATE table_reference SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ...
            [WHERE where_condition]
            [ORDER BY ...]
            [LIMIT row_count]               
        注意:一定要有限制条件,否则将修改整个表中指定字段的数据;
            限制条件:
                 [WHERE where_condition]
             [ORDER BY ...] [LIMIT row_count]
        注意:sql_safe_updates变量可阻止不带条件更新操作;       
SELECT:
    Query Cache:缓存查询的执行结果;
        key:查询语句的hash值; 
        value:查询语句的执行结果;        
SQL语句的编写方式:
        SELECT name FROM tbl2;
        select name from tbl2;
查询执行路径:
        请求-->查询缓存
        请求-->查询缓存-->解析器-->预处理器-->优化器-->查询执行引擎-->存储引擎-->缓存-->响应                                      
SELECT语句的执行流程:
    FROM  --> WHERE --> Group By --> Having --> Order BY --> SELECT --> Limit 8、单表查询:
    SELECT
         [ALL | DISTINCT | DISTINCTROW ]
        [SQL_CACHE | SQL_NO_CACHE] [SQL_CALC_FOUND_ROWS]
            select_expr [, select_expr ...]
                    [FROM table_references
                    [WHERE where_condition]
                [GROUP BY {col_name | expr | position}
                [ASC | DESC], ... [WITH ROLLUP]]
                [HAVING where_condition]
                [ORDER BY {col_name | expr | position}
                [ASC | DESC], ...]
                [LIMIT {[offset,] row_count | row_count OFFSET offset}] 
                    
    用法:
        SELECT col1, col2, ... FROM tble_name;   极其危险,慎用;
        SELECT col1, col2, ... FROM tble_name WHERE clause;
        SELECT col1, col2, ... FROM tble_name  [WHERE clause] GROUP BY col_name [HAVING clause]; 
        DISTINCT:数据去重;
        SQL_CACHE:显式指定缓存查询语句的结果;
        SQL_NO_CACHE:显式指定不缓存查询语句的结果;
            query_cache_type服务器变量有三个值:
                    ON:启用; 
                        SQL_NO_CACHE:不缓存;默认符合缓存条件都缓存;
                    OFF:关闭;
                    DEMAND:按需缓存;
                        SQL_CACHE:缓存;默认不缓存;
            字段可以使用别名 :
                    col1 AS alias1, col2 AS alias2, ...
                    
            WHERE子句:指明过滤条件以实现“选择”功能;
                    过滤条件:布尔型表达式;
                    
                    [WHERE where_condition]
                        算术操作符:+, -, *, /, %
                        比较操作符:=, <>, !=, <=>, >, >=, <, <=
                        
                        IS NULL, IS NOT NULL
                        区间:BETWEEN min AND max 
                        IN:列表;
                        LIKE:模糊比较,%和_;
                        RLIKE或REGEXP
                            
                        逻辑操作符:
                            AND, OR, NOT
                            
        GROUP BY:根据指定的字段把查询的结果进行“分组”以用于“聚合”运算;
                    avg(), max(), min(), sum(), count()

                    HAVING:对分组聚合后的结果进行条件过滤;
                    
        ORDER BY:根据指定的字段把查询的结果进行排序;
                    升序:ASC
                    降序:DESC 
                    
        LIMIT:对输出结果进行数量限制
                    [LIMIT {[offset,] row_count | row_count OFFSET offset}]

9、多表查询:

        连接操作:
        交叉连接:笛卡尔乘积;
        连接:
            等值连接:让表之间的字段以等值的方式建立连接;
            不等值连接:
            自然连接
            自连接
        外连接:
            左外连接:
            FROM tb1 LEFT JOIN tb2 ON tb1.col = tb2.col 
            右外连接:
            FROM tb1 RIGHT JOIN tb2 ON tb1.col = tb2.col 
                            
子查询:在查询中嵌套查询;
  用于WHERE子句中的子查询;
        (1) 用于比较表达式中的子查询:子查询仅能返回单个值; 
        (2) 用于IN中的子查询:子查询可以返回一个列表值; 
        (3) 用于EXISTS中的子查询:
 用于FROM子句中的子查询;
    SELECT tb_alias.col1, ... FROM (SELECT clause) AS tb_alias WHERE clause; 
    联合查询:将多个查询语句的执行结果相合并;
                UNION 
    SELECT clause UNION SELECT cluase;
        MySQL --> MariaDB --> Percona-Server
                   InnoDB --> XtraDB

10、 存储引擎:

   表类型:也称为“表类型”,表级别概念,不建议在同一个库中的表上使用不同的ENGINE;
        CREATE TABLE ... ENGINE[=]STORAGE_ENGINE_NAME ...
        SHOW TABLE STATUS 
     常见的存储引擎:SHOW ENGINES;
        MyISAM, Aria, InnoDB, MRG_MYISAM, CSV, BLACKHOLE, MEMORY, PERFORMANCE_SCHEMA, ARCHIVE, FEDERATED
clipboard2.png
clipboard3.png
clipboard4.png

InnoDB:InnoBase

    Percona-XtraDB, Supports transactions, row-level locking, and foreign keys
   数据存储于“表空间(table space)"中:
    (1) 所有数据库中的所有类型为InnoDB的表的数据和索引存储于同一个表空间中;
                    空间文件:datadir定义的目录中
            文件:ibdata1, ibdata2, ...
    (2) innodb_file_per_table=ON,意味着每表使用单独的表空间文件;
            每表的数据文件(数据和索引,存储于数据库目录)存储于自己专用的表
                        空间文件中,并存储于数据库目录下: tbl_name.ibd 
                    
                表结构的定义:在数据库目录,tbl_name.frm 
                
事务型存储引擎,适合对事务要求较高的场景中;但较适用于处理大量短期事务;
基于MVCC(Mutli Version Concurrency Control)支持高并发;支持四个隔离级   别,默认级别为REPEATABLE-READ;间隙锁以防止幻读;
            使用聚集索引(主键索引);
            支持”自适应Hash索引“;
            锁粒度:行级锁;间隙锁;
            
            总结:
                数据存储:表空间;
                并发:MVCC,间隙锁,行级锁;
                索引:聚集索引、辅助索引;
                性能:预读操作、内存数据缓冲、内存索引缓存、
                                           自适应Hash索引、插入操作缓存区;
                备份:支持热备;
        SHOW ENGINE INNODB STATUS;

MyISAM:

            支持全文索引(FULLTEXT index)、压缩、空间函数(GIS);
            不支持事务
            锁粒度:表级锁
            崩溃无法保证表安全恢复
    适用场景:只读或读多写少的场景、较小的表(以保证崩溃后恢复的时间较短);
            
    文件:每个表有三个文件,存储于数据库目录中
        tbl_name.frm:表格式定义;
        tbl_name.MYD:数据文件; 
        tbl_name.MYI:索引文件;
                
    特性:
        加锁和并发:表级锁;
        修复:手动或自动修复、但可能会丢失数据;
        索引:非聚集索引;
        延迟索引更新;
        表压缩;
                
         行格式:
        {DEFAULT|DYNAMIC|FIXED|COMPRESSED|REDUNDANT|COMPACT}
             
    其它的存储引擎:
        CSV:将CSV文件(以逗号分隔字段的文本文件)作为MySQL表文件; 
        MRG_MYISAM:将多个MyISAM表合并成的虚拟表;
        BLACKHOLE:类似于/dev/null,不真正存储数据;
        MEMORY:内存存储引擎,支持hash索引,表级锁,常用于临时表;
        FEDERATED: 用于访问其它远程MySQL服务器上表的存储引擎接口;
    MariaDB额外支持很多种存储引擎:
          OQGraph、SphinxSE、TokuDB、Cassandra、CONNECT、SQUENCE、...
        搜索引擎:
           lucene, sphinx 
           lucene:Solr, ElasticSearch 

11、并发控制:

    锁:Lock (语句执行是会自动加锁)
    锁类型 :
        读锁:共享锁,可被多个读操作共享;
        写锁:排它锁,独占锁;
    锁粒度:
                表锁:在表级别施加锁,并发性较低;
        行锁:在行级别施加锁,并发性较高;维持锁状态的成本较大;
    锁策略:在锁粒度及数据安全性之间寻求一种平衡机制;
        存储引擎:级别以及何时施加或释放锁由存储引擎自行决定;
        MySQL Server:表级别,可自行决定,也允许显式请求; 
    锁类别:
                显式锁:用户手动请求的锁;
        隐式锁:存储引擎自行根据需要施加的锁;
    显式锁的使用:
        (1) LOCK TABLES 
                LOCK TABLES  tbl_name  read|write, tbl_name read|write, ...
                UNLOCK TABLES
                
             (2) FLUSH TABLES(刷写,将内存数据同步到磁盘文件上)
                FLUSH TABLES tbl_name,... [WITH READ LOCK];
                UNLOCK TABLES;  
         (3) SELECT cluase
                [FOR UPDATE | LOCK IN SHARE MODE]
clipboard5.png

事务:

    事务:一组原子性的SQL查询、或者是一个或多个SQL语句组成的独立工作单元;
        事务日志:
                innodb_log_files_in_group  
                innodb_log_group_home_dir
                innodb_log_file_size    
                innodb_mirrored_log_groups
ACID测试:
    A:AUTOMICITY,原子性;整个事务中的所有操作要么全部成功执行,要么全部失败后回滚;
    C:CONSISTENCY,一致性;数据库总是应该从一个一致性状态转为另一个一致性状态; 
    I:ISOLATION,隔离性;一个事务所做出的操作在提交之前,是否能为其它事务可见;出于保证并发操作之目的,隔离有多种级别; 
    D:DURABILITY,持久性;事务一旦提交,其所做出的修改会永久保存;
            
自动提交:单语句事务
            mysql> SELECT @@autocommit;
            +------------------------+
            | @@autocommit |
            +------------------------+
            |            1               |
            +------------------------+
            
            mysql> SET @@session.autocommit=0;
            
手动控制事务:
        启动:START TRANSACTION 
        提交:COMMIT
        回滚:ROLLBACK
            
事务支持savepoints(保存点):类似于快照
        SAVEPOINT identifier
        ROLLBACK [WORK] TO [SAVEPOINT] identifier
        RELEASE SAVEPOINT identifier    
clipboard6.png
clipboard7.png

事务隔离级别:

        READ-UNCOMMITTED:读未提交 --> 脏读;
        READ-COMMITTED:读提交--> 不可重复读;
        REPEATABLE-READ:可重复读 --> 幻读;
        SERIALIZABLE:串行化;
            
            mysql> SELECT @@session.tx_isolation;
            +----------------------------------+
            | @@session.tx_isolation |
            +----------------------------------+
            | REPEATABLE-READ         |
            +----------------------------------+
            
查看InnoDB存储引擎的状态信息:
            SHOW ENGINE innodb STATUS;                      
MySQL用户和权限管理 
        用户账号:user@host
            user:账户名称;
            host:此账户可通过哪些客户端主机请求创建连接线程; 
                %:任意长度的任意字符;
                _:任意单个字符;
                
                skip_name_resolve=ON
        
MySQL权限类别:
        库级别:
        表级别:
        字段级别:
        管理类:
        程序类:
        
    管理类:
        CREATE USER
        RELOAD
        LOCK TABLES
        REPLICATION CLIENT, REPLICATION SLAVE
        SHUTDOWN
        FILE
        SHOW DATABASES
        PROCESS 
        SUPER
            
    程序类:
        FUNCTION,PROCEDURE,TRIGGER
            
    操作:
                CREATE,ALTER,DROP,EXECUTE
            
    库和表级别:
            CREATE,ALTER,DROP
            INDEX
            CREATE VIEW
            SHOW VIEW
            GRANT:能够把自己获得的权限生成一个副本转赠给其它用户;
            OPTION
            
        数据操作:
            表:
                INSERT/DELETE/UPDATE/SELECT 
                
            字段:
                SELECT(col1,col2,...)
                UPDATE(col1,col2,...)
                INSERT(col1,col2,...)
                
        所有权限:ALL, ALL PRIVILEGES
        
        元数据数据库(数据字典):mysql
            授权:
                db, host, user
                tables_priv, column_priv, procs_priv, proxies_priv
                
    MySQL的索引:
        
        MySQL用户管理:
            'user'@'host';
                host:
                    IP
                    主机名             
                    NETWORK
                        %, _            

创建用户:

CREATE USER 'user'@'host' [IDENTIFIED BY [PASSWORD] 'password'] [,'user'@'host' [IDENTIFIED BY [PASSWORD] 'password']...]
重命名:RENAME USER

删除用户:

DROP USER 'user'@'host' [, 'user'@'host'] ...
让MySQL重新加载授权表:
FLUSH PRIVILEGES

修改用户密码:

(1) SET PASSWORD [FOR 'user'@'host'] = PASSWORD('cleartext password');
(2) UPDATE mysql.user SET Password=PASSWORD('cleartext password')
WHERE User='USERNAME' AND Host='HOST';
(3) mysqladmin -uUSERNAME -hHOST -p password 'NEW_PASS'
生效:FLUSH PRIVILEGES

忘记管理员密码的解决办法:

    (1) 启动mysqld进程时,使用--skip-grant-tables和--skip-networking选项;
            CentOS 7:mariadb.service
            CentOS 6:/etc/init.d/mysqld
    (2) 通过UPDATE命令修改管理员密码; 
    (3) 以正常 方式启动mysqld进程;

授权:GRANT

GRANT priv_type [(column_list)] [, priv_type [(column_list)]] ...
ON [object_type] priv_level
TO user_specification [, user_specification] ...
[REQUIRE {NONE | ssl_option [[AND] ssl_option] ...}]
[WITH with_option ...]
```
object_type:
TABLE
| FUNCTION
| PROCEDURE

            priv_level:
                *
                | *.*
                | db_name.*
                | db_name.tbl_name
                | tbl_name
                | db_name.routine_name
                
                
            ssl_option:
                SSL
                | X509
                | CIPHER 'cipher'
                | ISSUER 'issuer'
                | SUBJECT 'subject'             
            
            with_option:
                GRANT OPTION
                | MAX_QUERIES_PER_HOUR count
                | MAX_UPDATES_PER_HOUR count
                | MAX_CONNECTIONS_PER_HOUR count
                | MAX_USER_CONNECTIONS count    
                
查看授权:SHOW GRANTS
    SHOW GRANTS [FOR 'user'@'host']
                
取消授权:REVOKE
    REVOKE  priv_type [(column_list)][, priv_type [(column_list)]] ...
        ON [object_type] priv_level
        FROM  'user'@'host' [,  'user'@'host'] ...
            
    REVOKE ALL PRIVILEGES, GRANT OPTION
        FROM user [, user] ...
MySQL的索引:
          索引:提取索引的创建在的表上字段中的数据,构建出一个独特的数据结构;
        索引的作用:加速查询操作;副作用:降低写操作性能;
        表中数据子集:把表中某个或某些字段的数据提取出来另存为一个特定数
                                            据结构组织的数据;
        某个字段或某些字段:WHERE子句中用到的字段;
                
        索引类型:B+ TREE,HASH
        B+ TREE:顺序存储,每一个叶子结点到根结点的距离相同;左前缀索
                                           引,适合于范围类型的数据查询;
            
        适用于B+ TREE索引的查询类型:全键值、键值范围或键前缀;
              全值匹配:精确匹配某个值;
                    WHERE COLUMN = 'value';
            匹配最左前缀:只精确匹配起头的部分;
                    WEHRE COLUMN LIKE 'PREFIX%';                        
            匹配范围值:
                精确匹配某一列,范围匹配另一列;
            只用访问索引的查询:覆盖索引;
                    index(Name)
                SELECT Name FROM students WHERE Name LIKE 'L%';
                                            
        不适用B+ TREE索引:
        如果查询条件不是从最左侧列开始,索引无效;
    index(age,Fname), WHERE Fname='Jerry';    , WHERE age>30 AND Fname='Smith';
                    不能跳过索引中的某列;
                        index(name,age,gender)
                            WHERE name='black' and age > 30;
                            WHERE name='black' AND gender='F';
    如果查询中的某个列是为范围查询,那么其右侧的列都无法再使用索引优化查询;
                        WHERE age>30 AND Fname='Smith';
                
        Hash索引:基于哈希表实现,特别适用于值的精确匹配查询;
        只支持等值比较查询,例如=, IN(), <=>
    不用场景:
        所有非精确值查询;MySQL仅对memory存储引擎支持显式的hash索引;
                
索引优点:
        降低需要扫描的数据量,减少IO次数;
        可以帮助避免排序操作,避免使用临时表; 
        帮助将随机IO转为顺序IO;

高性能索引策略:

(1) 在WHERE中独立使用列,尽量避免其参与运算;
        WHERE age+2 > 32 ; 
(2) 左前缀索引:索引构建于字段的最左侧的多少个字符,要通过索引选择性来评估
        索引选择性:不重复的索引值和数据表的记录总数的比值;
(3) 多列索引:
        AND连接的多个查询条件更适合使用多列索引,而非多个单键索引;
(4) 选择合适的索引列次序:选择性最高的放左侧;

EXPLAIN来分析索引有效性:

EXPLAIN [explain_type] SELECT select_options
        explain_type:
            EXTENDED
            | PARTITIONS    
    
    输出结果:
                id: 1
        select_type: SIMPLE
            table: students
            type: const
        possible_keys: PRIMARY
            key: PRIMARY
        key_len: 4
            ref: const
            rows: 1
            Extra: 
id:当前查询语句中,第个SELECT语句的编号;
        复杂的查询的类型主要三种:
            简单子查询
            用于FROM中的子查询
            联合查询
    注意:联合查询的分析结果会出现一个额外的匿名临时表;
                    
select_type:查询类型:
             简单查询:SIMPLE
            复杂查询:
            简单子查询:SUBQUERY
            用于FROM中的子查询:DERIVED
            联合查询中的第一个查询:PRIMARY
            联合查询中的第一个查询之后的其它查询:UNION
            联合查询生成的临时表:UNION RESULT
table:查询针对的表;
type:关联类型,或称为访问类型,即MySQL如何去查询表中的行
        ALL:全表扫描;
        index:根据索引的顺序进行的全表扫描;但同时如果Extra列出现了"Using 
                              index”表示使用了覆盖索引;
range:有范围限制地根据索引实现范围扫描;扫描位置始于索引中的某一项,结束于另一项;
ref:根据索引返回的表中匹配到某单个值的所有行(匹配给定值的行不止一个);
eq_ref:根据索引返回的表中匹配到某单个值的单一行,仅返回一个行,但需要与某个
               额外的参考值比较,而不是常数;
const,system:与某个常数比较,且只返回一行;
possiable_keys:查询中可能会用到的索引;
key:查询中使用的索引;   
key_len:查询中用到的索引长度;
ref:在利用key字段所显示的索引完成查询操作时所引用的列或常量值; 
rows:MySQL估计出的为找到所有的目标项而需要读取的行数;
                
Extra:额外信息
    Using index:使用了覆盖索引进行的查询;
    Using where:拿到数据后还要再次进行过滤; 
        Using temporary:使用了临时表以完成查询;
    Using filesort:对结果使用了一个外部索引排序;              
查询缓存:
    缓存:k/v 
                key:查询语句的hash值
            value:查询语句的执行结果
    如何判断缓存是否命中:
            通过查询语句的哈希值判断:哈希值考虑的因素包括
                查询本身、要查询数据库、客户端使用的协议版本、...
                    SELECT Name FROM students WHERE StuID=3;
                    Select Name From students where StuID=3;
    哪些查询可能不会被缓存?
            查询语句中包含UDF
            存储函数
            用户自定义变量
            临时表
            mysql系统表或者是包含列级别权限的查询
            有着不确定结果值的函数(now()); 
    查询缓存相关的服务器变量:
        query_cache_limit:能够缓存的最大查询结果;(单语句结果集大小上限)
                                          有着较大结果集的语句,显式使用SQL_NO_CACHE,
                                                  以避免先缓存再移出; 
            query_cache_min_res_unit:内存块的最小分配单位;缓存过小的查询结果
                                                     集会浪费内存空间;
        较小的值会减少空间浪费,但会导致更频繁地内存分配及回收操作; 
          较大值的会带来空间浪费;
        query_cache_size:查询缓存空间的总共可用的大小;单位是字节,必须是
                                                 1024的整数倍;
        query_cache_strip_comments
        query_cache_type:缓存功能启用与否;
                ON:启用;
                OFF:禁用;
        DEMAND:按需缓存,仅缓存SELECT语句中带SQL_CACHE的查询结果;
        query_cache_wlock_invalidate:如果某表被其它连接锁定,是否仍然可以
                                                  从查询缓存中返回查询结果;默认为OFF,表示可以;
                                                 ON则表示不可以;
    状态变量:
        mysql> SHOW GLOBAL STATUS LIKE 'Qcache%';
             +-------------------------+----------+
            | Variable_name           | Value    |
            +-------------------------+----------+
            | Qcache_free_blocks      | 1        |
            | Qcache_free_memory      | 16759688 |
            | Qcache_hits             | 0        |
            | Qcache_inserts          | 0        |
            | Qcache_lowmem_prunes    | 0        |
            | Qcache_not_cached       | 0        |
            | Qcache_queries_in_cache | 0        |
            | Qcache_total_blocks     | 1        |
            +-------------------------+----------+      
            
    命中率:
         Qcache_hits/Com_select 
##日志:
    >   查询日志:general_log
        慢查询日志:log_slow_queries
        错误日志:log_error, log_warnings
        二进制日志:binlog
        中继日志:relay_log
        事务日志:innodb_log
1、查询日志
        记录查询语句,日志存储位置:
            文件:file
            表:table (mysql.general_log)
            
        general_log={ON|OFF}
        general_log_file=HOSTNAME.log 
        log_output={FILE|TABLE|NONE}
2、慢查询日志
        慢查询:运行时间超出指定时长的查询;
            long_query_time
        存储位置:
            文件:FILE
            表:TABLE,mysql.slog_log
            
        log_slow_queries={ON|OFF}
        slow_query_log={ON|OFF}
        slow_query_log_file=
        log_output={FILE|TABLE|NONE}
        log_slow_filter=admin,filesort,filesort_on_disk,full_join,full_scan,query_cache,query_cache_miss,tmp_table,tmp_table_on_disk
        log_slow_rate_limit
        log_slow_verbosity
3、错误日志
    记录如下几类信息:
        (1) mysqld启动和关闭过程中输出的信息; 
        (2) mysqld运行中产生的错误信息; 
        (3) event scheduler运行时产生的信息;
        (4) 主从复制架构中,从服务器复制线程启动时产生的日志;
log_error=
        /var/log/mariadb/mariadb.log|OFF
log_warnings={ON|OFF}

4、二进制日志

        用于记录引起数据改变或存在引起数据改变的潜在可能性的语句(STATEMENT)或改变后的结果(ROW),也可能是二者混合;
            功用:“重放”
            
            binlog_format={STATEMENT|ROW|MIXED}
                STATEMENT:语句;
                ROW:行;
                MIXED:混编;
                
        查看二进制日志文件列表:
                 SHOW MASTER|BINARY LOGS;
                 
        查看当前正在使用的二进制日志文件:
                SHOW MASTER STATUS;
                
        查看二进制 日志文件中的事件:
                           SHOW BINLOG EVENTS    [IN 'log_name'] [FROM pos] [LIMIT [offset,] row_count]
                
        服务器变量:
            log_bin=/PATH/TO/BIN_LOG_FILE
                只读变量;
            session.sql_log_bin={ON|OFF}
                控制某会话中的“写”操作语句是否会被记录于日志文件中;
            max_binlog_size=1073741824
            sync_binlog={1|0}
                
            mysqlbinlog:
                    YYYY-MM-DD hh:mm:ss
                
                 --start-datetime=
                 --stop-datetime=
                 
                 -j, --start-position=#
                  --stop-position=#
                  
                  --user, --host, --password

二进制日志事件格式:

    # at 553
    #160831  9:56:08 server id 1  end_log_pos 624   Query   thread_id=2     exec_time=0     error_code=0
        SET TIMESTAMP=1472608568/*!*/;
        BEGIN
            /*!*/;
        事件的起始位置:# at 553
    事件发生的日期时间:#160831  9:56:08
    事件发生的服务器id:server id 1
    事件的结束位置:end_log_pos 624
    事件的类型:Query
    事件发生时所在服务器执行此事件的线程的ID: thread_id=2 
    语句的时间戳与将其写入二进制日志文件中的时间差:exec_time=0
    错误代码:error_code=0
    设定事件发生时的时间戳:SET TIMESTAMP=1472608568/*!*/;
    事件内容:BEGIN
中继日志:
        从服务器上记录下来从主服务器的二进制日志文件同步过来的事件;
事务日志:
        事务型存储引擎innodb用于保证事务特性的日志文件:
                redo log 
                undo log        
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • 数据库基本概念回顾数据库的并发控制:锁MySQL的事务设置MySQL的索引设置MySQL的用户和权限管理 一、数据...
    哈喽别样阅读 341评论 0 0
  • MySQL进阶讲义 这一章我们开始进一步探讨MySQL的使用,从MySQL的介绍开始,接触MySQL的安装、命令行...
    厲铆兄阅读 2,183评论 0 44
  • 什么是数据库? 数据库是存储数据的集合的单独的应用程序。每个数据库具有一个或多个不同的API,用于创建,访问,管理...
    chen_000阅读 4,033评论 0 19
  • 0-索引 索引原理与优化 0.1- MyISAM/InnoDB索引原理(聚集索引、非聚集索引) 索引是在存储引擎层...
    zhanglbjames阅读 1,176评论 1 1
  • 总是感觉自己有很多很多的坏习惯,总想要改,每天早上起床的时候对自己说,今晚一定肯定不会再晚睡了,也不会再看小说...
    随心127阅读 350评论 0 0