• MySQL架构及SQL语句


    MySQL:单进程多线程
    MySQL数据文件类型:
    数据文件、索引文件
    日志文件:重做日志、撤销日志、二进制日志、错误日志、查询日志、慢查询日志、中继日志

    DDL & DML:
    索引管理:按特定数据结构存储的数据
    索引类型:
    聚集索引(一般都是主键索引)、非聚集索引、数据是否与索引存储在一起
    主键索引、辅助索引
    稠密索引、稀疏索引:是否索引了每一个数据项
    B+ TREE(B指的是Balance)平衡树索引、HASH索引、R TREE索引
    简单索引、组合索引

    MySQL索引的使用方式:左前缀索引(最左前缀索引)
    覆盖索引:不需要查找元数据,只通过索引就可以找到想到的数据

    管理索引的途径:
    创建索引: 创建表时指定:CREATE INDEX
    创建或删除索引:修改表的命令
    删除索引:DROP INDEX

    查看表上的索引:
    SHOW {INDEX | INDEXES | KEYS}
    {FROM | IN} tbl_name
    [{FROM | IN} db_name]
    [WHERE expr]
    SHOW INDEXES FROM user;

    使用EXPLAIN查看语句分析结果:
    EXPLAIN SELECT * FROM user WHERE User='root'G;

    视图:VIEW
    虚表
    创建方法:
    CREATE
    [OR REPLACE]
    [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
    [DEFINER = { user | CURRENT_USER }]
    [SQL SECURITY { DEFINER | INVOKER }]
    VIEW view_name [(column_list)]
    AS select_statement
    [WITH [CASCADED | LOCAL] CHECK OPTION]
    创建一个test的视图:CREATE VIEW test AS SELECT User,Host FROM user;

    视图中的数据事实上存储于"基表"中,因此,其修改操作也会针对基表实现,其修改操作受基表限制;

    DML:
    INSERT, DELETE, UPDATE, SELECT
    INSERT:
    一次插入一行或多行数据
    Syntax:
    INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
    [INTO] tbl_name
    [PARTITION (partition_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
    [PARTITION (partition_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
    [PARTITION (partition_name,...)]
    [(col_name,...)]
    SELECT ...
    [ ON DUPLICATE KEY UPDATE
    col_name=expr
    [, col_name=expr] ... ]

    DELETE:
    DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl_name
    [PARTITION (partition_name,...)]
    [WHERE where_condition]
    [ORDER BY ...]
    [LIMIT row_count]
    注意:一定要有限制条件,否则将清空表中的所有数据
    WHERE
    LIMIT

    UPDATE:
    UPDATE [LOW_PRIORITY] [IGNORE] table_reference
    SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ...
    [WHERE where_condition]
    [ORDER BY ...]
    [LIMIT row_count]
    注意:一定要有限制条件,否则将修改所有行的指定字段
    WHERE
    LIMIT
  • 相关阅读:
    Mybatis源码中最重要的几个类
    学习爬虫-运营商积分
    IntelliJ IDEA 最新版 2019.2.4 激活 (持续更新)(含windows和Mac)
    归并排序之求小和
    归并排序
    理解递归
    插入排序
    对数器
    冒泡排序
    mysql 数据库名称,中间带有中划线问题
  • 原文地址:https://www.cnblogs.com/fansik/p/7744658.html
Copyright © 2020-2023  润新知